Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(199)

Unified Diff: src/store-buffer.h

Issue 6309012: * Complete new store buffer on ia32. The store buffer now covers... (Closed) Base URL: http://v8.googlecode.com/svn/branches/experimental/gc/
Patch Set: '' Created 9 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: src/store-buffer.h
===================================================================
--- src/store-buffer.h (revision 6207)
+++ src/store-buffer.h (working copy)
@@ -50,17 +50,50 @@
static const int kStoreBufferOverflowBit = 1 << 16;
static const int kStoreBufferSize = kStoreBufferOverflowBit;
+ static const int kStoreBufferLength = kStoreBufferSize / sizeof(Address);
+ static const int kOldStoreBufferLength = kStoreBufferLength * 16;
static const int kHashMapLengthLog2 = 12;
static const int kHashMapLength = 1 << kHashMapLengthLog2;
static void Compact();
+ static void GCPrologue(GCType type, GCCallbackFlags flags);
+ static void GCEpilogue(GCType type, GCCallbackFlags flags);
+ static Object*** Start() { return reinterpret_cast<Object***>(old_start_); }
+ static Object*** Top() { return reinterpret_cast<Object***>(old_top_); }
+
+ static bool must_scan_entire_memory() { return must_scan_entire_memory_; }
+ static bool old_buffer_is_sorted() { return old_buffer_is_sorted_; }
+
+ // Goes through the store buffer removing pointers to things that have
+ // been promoted. Rebuilds the store buffer completely if it overflowed.
+ static void Clean();
Vyacheslav Egorov (Chromium) 2011/01/21 18:18:18 Should not be this wrapped into #ifdef DEBUG? Als
Erik Corry 2011/01/24 13:56:00 Done.
+ static void SortUniq();
Vyacheslav Egorov (Chromium) 2011/01/21 18:18:18 Better name?
Erik Corry 2011/01/24 13:56:00 I like it.
+ static void Verify();
+
private:
+ // The store buffer is divided up into a new buffer that is constantly being
+ // filled by mutator activity and an old buffer that is filled with the data
+ // from the new buffer after compression.
static Address* start_;
static Address* limit_;
+
+ static Address* old_start_;
+ static Address* old_limit_;
+ static Address* old_top_;
+
+ static bool old_buffer_is_sorted_;
+ static bool must_scan_entire_memory_;
+ static bool during_gc_;
+
static VirtualMemory* virtual_memory_;
static uintptr_t* hash_map_1_;
static uintptr_t* hash_map_2_;
+
+ static void CheckForFullBuffer();
+ static void Uniq();
+ static void ZapHashTables();
+ static bool HashTablesAreZapped();
};
} } // namespace v8::internal

Powered by Google App Engine
This is Rietveld 408576698