Index: test/mkgrokdump/mkgrokdump.cc |
diff --git a/test/mkgrokdump/mkgrokdump.cc b/test/mkgrokdump/mkgrokdump.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..e5a41a13ba3a7ce09b175c28ada3066a0752126a |
--- /dev/null |
+++ b/test/mkgrokdump/mkgrokdump.cc |
@@ -0,0 +1,133 @@ |
+// Copyright 2012 the V8 project authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include <stdio.h> |
+ |
+#include "include/libplatform/libplatform.h" |
+#include "include/v8.h" |
+ |
+#include "src/frames.h" |
+#include "src/heap/heap.h" |
+#include "src/heap/spaces.h" |
+#include "src/isolate.h" |
+#include "src/objects-inl.h" |
+ |
+namespace v8 { |
+ |
+static const char* kHeader = |
+ "# Copyright 2017 the V8 project authors. All rights reserved.\n" |
+ "# Use of this source code is governed by a BSD-style license that can\n" |
+ "# be found in the LICENSE file.\n" |
+ "\n" |
+ "# This file is automatically generated by mkgrokdump and should not\n" |
+ "# be modified manually.\n" |
+ "\n" |
+ "# List of known V8 instance types.\n"; |
+ |
+// Non-snapshot builds allocate objects to different places. |
+// Debug builds emit debug code, affecting code object sizes. |
+#if defined(V8_USE_SNAPSHOT) && !defined(DEBUG) |
+static const char* kBuild = "shipping"; |
+#else |
+static const char* kBuild = "non-shipping"; |
+#endif |
+ |
+class MockArrayBufferAllocator : public v8::ArrayBuffer::Allocator { |
+ public: |
+ void* Allocate(size_t length) override { return nullptr; } |
+ void* AllocateUninitialized(size_t length) override { return nullptr; } |
+ void Free(void* p, size_t) override {} |
+}; |
+ |
+static int DumpHeapConstants(const char* argv0) { |
+ // Start up V8. |
+ v8::Platform* platform = v8::platform::CreateDefaultPlatform(); |
+ v8::V8::InitializePlatform(platform); |
+ v8::V8::Initialize(); |
+ v8::V8::InitializeExternalStartupData(argv0); |
+ Isolate::CreateParams create_params; |
+ MockArrayBufferAllocator mock_arraybuffer_allocator; |
+ create_params.array_buffer_allocator = &mock_arraybuffer_allocator; |
+ Isolate* isolate = Isolate::New(create_params); |
+ { |
+ Isolate::Scope scope(isolate); |
+ i::Heap* heap = reinterpret_cast<i::Isolate*>(isolate)->heap(); |
+ i::PrintF("%s", kHeader); |
+#define DUMP_TYPE(T) i::PrintF(" %d: \"%s\",\n", i::T, #T); |
+ i::PrintF("INSTANCE_TYPES = {\n"); |
+ INSTANCE_TYPE_LIST(DUMP_TYPE) |
+ i::PrintF("}\n"); |
+#undef DUMP_TYPE |
+ |
+ // Dump the KNOWN_MAP table to the console. |
+ i::PrintF("\n# List of known V8 maps.\n"); |
+#define ROOT_LIST_CASE(type, name, camel_name) \ |
+ if (n == NULL && o == heap->name()) n = #camel_name; |
+#define STRUCT_LIST_CASE(upper_name, camel_name, name) \ |
+ if (n == NULL && o == heap->name##_map()) n = #camel_name "Map"; |
+ i::HeapObjectIterator it(heap->map_space()); |
+ i::PrintF("KNOWN_MAPS = {\n"); |
+ for (i::Object* o = it.Next(); o != NULL; o = it.Next()) { |
+ i::Map* m = i::Map::cast(o); |
+ const char* n = NULL; |
+ intptr_t p = reinterpret_cast<intptr_t>(m) & 0x7ffff; |
+ int t = m->instance_type(); |
+ ROOT_LIST(ROOT_LIST_CASE) |
+ STRUCT_LIST(STRUCT_LIST_CASE) |
+ if (n == NULL) continue; |
+ i::PrintF(" 0x%05" V8PRIxPTR ": (%d, \"%s\"),\n", p, t, n); |
+ } |
+ i::PrintF("}\n"); |
+#undef STRUCT_LIST_CASE |
+#undef ROOT_LIST_CASE |
+ |
+ // Dump the KNOWN_OBJECTS table to the console. |
+ i::PrintF("\n# List of known V8 objects.\n"); |
+#define ROOT_LIST_CASE(type, name, camel_name) \ |
+ if (n == NULL && o == heap->name()) { \ |
+ n = #camel_name; \ |
+ i = i::Heap::k##camel_name##RootIndex; \ |
+ } |
+ i::OldSpaces spit(heap); |
+ i::PrintF("KNOWN_OBJECTS = {\n"); |
+ for (i::PagedSpace* s = spit.next(); s != NULL; s = spit.next()) { |
+ i::HeapObjectIterator it(s); |
+ // Code objects are generally platform-dependent. |
+ if (s->identity() == i::CODE_SPACE) continue; |
+ const char* sname = AllocationSpaceName(s->identity()); |
+ for (i::Object* o = it.Next(); o != NULL; o = it.Next()) { |
+ const char* n = NULL; |
+ i::Heap::RootListIndex i = i::Heap::kStrongRootListLength; |
+ intptr_t p = reinterpret_cast<intptr_t>(o) & 0x7ffff; |
+ ROOT_LIST(ROOT_LIST_CASE) |
+ if (n == NULL) continue; |
+ if (!i::Heap::RootIsImmortalImmovable(i)) continue; |
+ i::PrintF(" (\"%s\", 0x%05" V8PRIxPTR "): \"%s\",\n", sname, p, n); |
+ } |
+ } |
+ i::PrintF("}\n"); |
+#undef ROOT_LIST_CASE |
+ |
+ // Dump frame markers |
+ i::PrintF("\n# List of known V8 Frame Markers.\n"); |
+#define DUMP_MARKER(T, class) i::PrintF(" \"%s\",\n", #T); |
+ i::PrintF("FRAME_MARKERS = (\n"); |
+ STACK_FRAME_TYPE_LIST(DUMP_MARKER) |
+ i::PrintF(")\n"); |
+#undef DUMP_TYPE |
+ } |
+ |
+ i::PrintF("\n# This set of constants is generated from a %s build.\n", |
+ kBuild); |
+ |
+ // Teardown. |
+ isolate->Dispose(); |
+ v8::V8::ShutdownPlatform(); |
+ delete platform; |
+ return 0; |
+} |
+ |
+} // namespace v8 |
+ |
+int main(int argc, char* argv[]) { return v8::DumpHeapConstants(argv[0]); } |