| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (C) 2013 Google Inc. All rights reserved. | 2 * Copyright (C) 2013 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 18 matching lines...) Expand all Loading... |
| 29 */ | 29 */ |
| 30 | 30 |
| 31 #include "platform/heap/HeapPage.h" | 31 #include "platform/heap/HeapPage.h" |
| 32 | 32 |
| 33 #include "base/trace_event/process_memory_dump.h" | 33 #include "base/trace_event/process_memory_dump.h" |
| 34 #include "platform/MemoryCoordinator.h" | 34 #include "platform/MemoryCoordinator.h" |
| 35 #include "platform/ScriptForbiddenScope.h" | 35 #include "platform/ScriptForbiddenScope.h" |
| 36 #include "platform/heap/BlinkGCMemoryDumpProvider.h" | 36 #include "platform/heap/BlinkGCMemoryDumpProvider.h" |
| 37 #include "platform/heap/CallbackStack.h" | 37 #include "platform/heap/CallbackStack.h" |
| 38 #include "platform/heap/HeapCompact.h" | 38 #include "platform/heap/HeapCompact.h" |
| 39 #include "platform/heap/MarkingVisitor.h" | |
| 40 #include "platform/heap/PageMemory.h" | 39 #include "platform/heap/PageMemory.h" |
| 41 #include "platform/heap/PagePool.h" | 40 #include "platform/heap/PagePool.h" |
| 42 #include "platform/heap/SafePoint.h" | 41 #include "platform/heap/SafePoint.h" |
| 43 #include "platform/heap/ThreadState.h" | 42 #include "platform/heap/ThreadState.h" |
| 44 #include "platform/instrumentation/tracing/TraceEvent.h" | 43 #include "platform/instrumentation/tracing/TraceEvent.h" |
| 45 #include "platform/instrumentation/tracing/web_memory_allocator_dump.h" | 44 #include "platform/instrumentation/tracing/web_memory_allocator_dump.h" |
| 46 #include "platform/instrumentation/tracing/web_process_memory_dump.h" | 45 #include "platform/instrumentation/tracing/web_process_memory_dump.h" |
| 47 #include "public/platform/Platform.h" | 46 #include "public/platform/Platform.h" |
| 48 #include "wtf/Assertions.h" | 47 #include "wtf/Assertions.h" |
| 49 #include "wtf/AutoReset.h" | 48 #include "wtf/AutoReset.h" |
| (...skipping 1643 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1693 // has not yet been initialized. In this case, we should mark the A | 1692 // has not yet been initialized. In this case, we should mark the A |
| 1694 // object without tracing any member of the A object. | 1693 // object without tracing any member of the A object. |
| 1695 visitor->markHeaderNoTracing(header); | 1694 visitor->markHeaderNoTracing(header); |
| 1696 ASSERT(isUninitializedMemory(header->payload(), header->payloadSize())); | 1695 ASSERT(isUninitializedMemory(header->payload(), header->payloadSize())); |
| 1697 } else { | 1696 } else { |
| 1698 visitor->markHeader(header, gcInfo->m_trace); | 1697 visitor->markHeader(header, gcInfo->m_trace); |
| 1699 } | 1698 } |
| 1700 } | 1699 } |
| 1701 | 1700 |
| 1702 void NormalPage::checkAndMarkPointer(Visitor* visitor, Address address) { | 1701 void NormalPage::checkAndMarkPointer(Visitor* visitor, Address address) { |
| 1703 ASSERT(contains(address)); | 1702 #if DCHECK_IS_ON() |
| 1703 DCHECK(contains(address)); |
| 1704 #endif |
| 1704 HeapObjectHeader* header = findHeaderFromAddress(address); | 1705 HeapObjectHeader* header = findHeaderFromAddress(address); |
| 1705 if (!header || header->isDead()) | 1706 if (!header || header->isDead()) |
| 1706 return; | 1707 return; |
| 1707 markPointer(visitor, header); | 1708 markPointer(visitor, header); |
| 1708 } | 1709 } |
| 1709 | 1710 |
| 1711 #if DCHECK_IS_ON() |
| 1712 void NormalPage::checkAndMarkPointer(Visitor* visitor, |
| 1713 Address address, |
| 1714 MarkedPointerCallbackForTesting callback) { |
| 1715 DCHECK(contains(address)); |
| 1716 HeapObjectHeader* header = findHeaderFromAddress(address); |
| 1717 if (!header || header->isDead()) |
| 1718 return; |
| 1719 if (!callback(header)) |
| 1720 markPointer(visitor, header); |
| 1721 } |
| 1722 #endif |
| 1723 |
| 1710 void NormalPage::markOrphaned() { | 1724 void NormalPage::markOrphaned() { |
| 1711 // Zap the payload with a recognizable value to detect any incorrect | 1725 // Zap the payload with a recognizable value to detect any incorrect |
| 1712 // cross thread pointer usage. | 1726 // cross thread pointer usage. |
| 1713 #if defined(ADDRESS_SANITIZER) | 1727 #if defined(ADDRESS_SANITIZER) |
| 1714 // This needs to zap poisoned memory as well. | 1728 // This needs to zap poisoned memory as well. |
| 1715 // Force unpoison memory before memset. | 1729 // Force unpoison memory before memset. |
| 1716 ASAN_UNPOISON_MEMORY_REGION(payload(), payloadSize()); | 1730 ASAN_UNPOISON_MEMORY_REGION(payload(), payloadSize()); |
| 1717 #endif | 1731 #endif |
| 1718 OrphanedPagePool::asanDisabledMemset( | 1732 OrphanedPagePool::asanDisabledMemset( |
| 1719 payload(), OrphanedPagePool::orphanedZapValue, payloadSize()); | 1733 payload(), OrphanedPagePool::orphanedZapValue, payloadSize()); |
| (...skipping 100 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1820 | 1834 |
| 1821 #if defined(ADDRESS_SANITIZER) | 1835 #if defined(ADDRESS_SANITIZER) |
| 1822 void LargeObjectPage::poisonUnmarkedObjects() { | 1836 void LargeObjectPage::poisonUnmarkedObjects() { |
| 1823 HeapObjectHeader* header = heapObjectHeader(); | 1837 HeapObjectHeader* header = heapObjectHeader(); |
| 1824 if (!header->isMarked()) | 1838 if (!header->isMarked()) |
| 1825 ASAN_POISON_MEMORY_REGION(header->payload(), header->payloadSize()); | 1839 ASAN_POISON_MEMORY_REGION(header->payload(), header->payloadSize()); |
| 1826 } | 1840 } |
| 1827 #endif | 1841 #endif |
| 1828 | 1842 |
| 1829 void LargeObjectPage::checkAndMarkPointer(Visitor* visitor, Address address) { | 1843 void LargeObjectPage::checkAndMarkPointer(Visitor* visitor, Address address) { |
| 1830 ASSERT(contains(address)); | 1844 #if DCHECK_IS_ON() |
| 1845 DCHECK(contains(address)); |
| 1846 #endif |
| 1831 if (!containedInObjectPayload(address) || heapObjectHeader()->isDead()) | 1847 if (!containedInObjectPayload(address) || heapObjectHeader()->isDead()) |
| 1832 return; | 1848 return; |
| 1833 markPointer(visitor, heapObjectHeader()); | 1849 markPointer(visitor, heapObjectHeader()); |
| 1834 } | 1850 } |
| 1835 | 1851 |
| 1852 #if DCHECK_IS_ON() |
| 1853 void LargeObjectPage::checkAndMarkPointer( |
| 1854 Visitor* visitor, |
| 1855 Address address, |
| 1856 MarkedPointerCallbackForTesting callback) { |
| 1857 DCHECK(contains(address)); |
| 1858 if (!containedInObjectPayload(address) || heapObjectHeader()->isDead()) |
| 1859 return; |
| 1860 if (!callback(heapObjectHeader())) |
| 1861 markPointer(visitor, heapObjectHeader()); |
| 1862 } |
| 1863 #endif |
| 1864 |
| 1836 void LargeObjectPage::markOrphaned() { | 1865 void LargeObjectPage::markOrphaned() { |
| 1837 // Zap the payload with a recognizable value to detect any incorrect | 1866 // Zap the payload with a recognizable value to detect any incorrect |
| 1838 // cross thread pointer usage. | 1867 // cross thread pointer usage. |
| 1839 OrphanedPagePool::asanDisabledMemset( | 1868 OrphanedPagePool::asanDisabledMemset( |
| 1840 payload(), OrphanedPagePool::orphanedZapValue, payloadSize()); | 1869 payload(), OrphanedPagePool::orphanedZapValue, payloadSize()); |
| 1841 BasePage::markOrphaned(); | 1870 BasePage::markOrphaned(); |
| 1842 } | 1871 } |
| 1843 | 1872 |
| 1844 void LargeObjectPage::takeSnapshot( | 1873 void LargeObjectPage::takeSnapshot( |
| 1845 base::trace_event::MemoryAllocatorDump* pageDump, | 1874 base::trace_event::MemoryAllocatorDump* pageDump, |
| (...skipping 65 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1911 | 1940 |
| 1912 m_hasEntries = true; | 1941 m_hasEntries = true; |
| 1913 size_t index = hash(address); | 1942 size_t index = hash(address); |
| 1914 ASSERT(!(index & 1)); | 1943 ASSERT(!(index & 1)); |
| 1915 Address cachePage = roundToBlinkPageStart(address); | 1944 Address cachePage = roundToBlinkPageStart(address); |
| 1916 m_entries[index + 1] = m_entries[index]; | 1945 m_entries[index + 1] = m_entries[index]; |
| 1917 m_entries[index] = cachePage; | 1946 m_entries[index] = cachePage; |
| 1918 } | 1947 } |
| 1919 | 1948 |
| 1920 } // namespace blink | 1949 } // namespace blink |
| OLD | NEW |