X-Git-Url: https://git.saurik.com/apple/javascriptcore.git/blobdiff_plain/f9bf01c6616d5ddcf65b13b33cedf9e387ff7a63..14957cd040308e3eeec43d26bae5d76da13fcd85:/interpreter/RegisterFile.cpp?ds=sidebyside diff --git a/interpreter/RegisterFile.cpp b/interpreter/RegisterFile.cpp index 510effe..e3b34bb 100644 --- a/interpreter/RegisterFile.cpp +++ b/interpreter/RegisterFile.cpp @@ -29,31 +29,73 @@ #include "config.h" #include "RegisterFile.h" +#include "ConservativeRoots.h" +#include "Interpreter.h" +#include "JSGlobalData.h" +#include "JSGlobalObject.h" + namespace JSC { +static size_t committedBytesCount = 0; + +static Mutex& registerFileStatisticsMutex() +{ + DEFINE_STATIC_LOCAL(Mutex, staticMutex, ()); + return staticMutex; +} + RegisterFile::~RegisterFile() { -#if HAVE(MMAP) - munmap(m_buffer, ((m_max - m_start) + m_maxGlobals) * sizeof(Register)); -#elif HAVE(VIRTUALALLOC) -#if OS(WINCE) - VirtualFree(m_buffer, DWORD(m_commitEnd) - DWORD(m_buffer), MEM_DECOMMIT); -#endif - VirtualFree(m_buffer, 0, MEM_RELEASE); -#else - fastFree(m_buffer); -#endif + void* base = m_reservation.base(); + m_reservation.decommit(base, reinterpret_cast(m_commitEnd) - reinterpret_cast(base)); + addToCommittedByteCount(-(reinterpret_cast(m_commitEnd) - reinterpret_cast(base))); + m_reservation.deallocate(); +} + +void RegisterFile::gatherConservativeRoots(ConservativeRoots& conservativeRoots) +{ + for (Register* it = start(); it != end(); ++it) { + JSValue v = it->jsValue(); + if (!v.isCell()) + continue; + conservativeRoots.add(v.asCell()); + } } void RegisterFile::releaseExcessCapacity() { -#if HAVE(MMAP) && HAVE(MADV_FREE) && !HAVE(VIRTUALALLOC) - while (madvise(m_start, (m_max - m_start) * sizeof(Register), MADV_FREE) == -1 && errno == EAGAIN) { } -#elif HAVE(VIRTUALALLOC) - VirtualFree(m_start, (m_max - m_start) * sizeof(Register), MEM_DECOMMIT); + m_reservation.decommit(m_start, reinterpret_cast(m_commitEnd) - reinterpret_cast(m_start)); + addToCommittedByteCount(-(reinterpret_cast(m_commitEnd) - reinterpret_cast(m_start))); m_commitEnd = m_start; -#endif m_maxUsed = m_start; } +void RegisterFile::setGlobalObject(JSGlobalObject* globalObject) +{ + m_globalObject.set(globalObject->globalData(), globalObject, &m_globalObjectOwner, this); +} + +JSGlobalObject* RegisterFile::globalObject() +{ + return m_globalObject.get(); +} + +void RegisterFile::initializeThreading() +{ + registerFileStatisticsMutex(); +} + +size_t RegisterFile::committedByteCount() +{ + MutexLocker locker(registerFileStatisticsMutex()); + return committedBytesCount; +} + +void RegisterFile::addToCommittedByteCount(long byteCount) +{ + MutexLocker locker(registerFileStatisticsMutex()); + ASSERT(static_cast(committedBytesCount) + byteCount > -1); + committedBytesCount += byteCount; +} + } // namespace JSC