Add extra guards for window-only performance checking

This commit is contained in:
gingerBill
2020-04-07 11:47:28 +01:00
parent 7ff690500a
commit 29a3cb25d3
3 changed files with 17 additions and 11 deletions

View File

@@ -442,15 +442,15 @@ bool ast_node_expect(Ast *node, AstKind kind) {
}
gb_global isize volatile total_allocated_node_memory = 0;
gb_global isize volatile total_subtype_node_memory_test = 0;
gb_global gbAtomic64 total_allocated_node_memory = {0};
gb_global gbAtomic64 total_subtype_node_memory_test = {0};
// NOTE(bill): And this below is why is I/we need a new language! Discriminated unions are a pain in C/C++
Ast *alloc_ast_node(AstFile *f, AstKind kind) {
gbAllocator a = ast_allocator();
_InterlockedExchangeAdd64(&total_allocated_node_memory, gb_size_of(Ast));
_InterlockedExchangeAdd64(&total_subtype_node_memory_test, gb_size_of(AstCommonStuff) + ast_variant_sizes[kind]);
gb_atomic64_fetch_add(&total_allocated_node_memory, cast(i64)(gb_size_of(Ast)));
gb_atomic64_fetch_add(&total_subtype_node_memory_test, cast(i64)(gb_size_of(AstCommonStuff) + ast_variant_sizes[kind]));
Ast *node = gb_alloc_item(a, Ast);
node->kind = kind;