aboutsummaryrefslogtreecommitdiff
path: root/src/timings.cpp
diff options
context:
space:
mode:
authorgingerBill <gingerBill@users.noreply.github.com>2025-01-06 13:43:01 +0000
committerGitHub <noreply@github.com>2025-01-06 13:43:01 +0000
commit6e49bbb66853b5d824ac5bbd534ae3e81c4f39aa (patch)
tree50886a3be8f2fcfab053e07cfe9e15f50fa5f9f6 /src/timings.cpp
parentbd96cd0af761994210018ca647eb843dfeb71494 (diff)
parent98efb03934b464a1b23759b5695a12ff37588357 (diff)
Merge branch 'master' into d3d11-annotations
Diffstat (limited to 'src/timings.cpp')
-rw-r--r--src/timings.cpp30
1 files changed, 16 insertions, 14 deletions
diff --git a/src/timings.cpp b/src/timings.cpp
index baa8b80da..3f8402b36 100644
--- a/src/timings.cpp
+++ b/src/timings.cpp
@@ -33,22 +33,23 @@ gb_internal u64 win32_time_stamp__freq(void) {
#include <mach/mach_time.h>
+gb_internal mach_timebase_info_data_t osx_init_timebase_info(void) {
+ mach_timebase_info_data_t data;
+ data.numer = 0;
+ data.denom = 0;
+ kern_return_t r = mach_timebase_info(&data);
+ GB_ASSERT(r == KERN_SUCCESS);
+
+ return data;
+}
+
gb_internal u64 osx_time_stamp_time_now(void) {
return mach_absolute_time();
}
gb_internal u64 osx_time_stamp__freq(void) {
- mach_timebase_info_data_t data;
- data.numer = 0;
- data.denom = 0;
- mach_timebase_info(&data);
-#if defined(GB_CPU_ARM)
- // NOTE(bill, 2021-02-25): M1 Chip seems to have a different freq count
- // TODO(bill): Is this truly correct?
- return (1000000llu * cast(u64)data.numer) / cast(u64)data.denom;
-#else
- return (1000000000llu * cast(u64)data.numer) / cast(u64)data.denom;
-#endif
+ gb_local_persist mach_timebase_info_data_t data = osx_init_timebase_info();
+ return 1000000000ull * cast(u64)data.denom / cast(u64)data.numer;
}
#elif defined(GB_SYSTEM_UNIX)
@@ -145,9 +146,10 @@ gb_internal f64 time_stamp_as_us(TimeStamp const &ts, u64 freq) {
return 1000000.0*time_stamp_as_s(ts, freq);
}
-#define MAIN_TIME_SECTION(str) do { debugf("[Section] %s\n", str); timings_start_section(&global_timings, str_lit(str)); } while (0)
-#define TIME_SECTION(str) do { debugf("[Section] %s\n", str); if (build_context.show_more_timings) timings_start_section(&global_timings, str_lit(str)); } while (0)
-#define TIME_SECTION_WITH_LEN(str, len) do { debugf("[Section] %s\n", str); if (build_context.show_more_timings) timings_start_section(&global_timings, make_string((u8 *)str, len)); } while (0)
+#define MAIN_TIME_SECTION(str) do { debugf("[Section] %s\n", str); timings_start_section(&global_timings, str_lit(str)); } while (0)
+#define MAIN_TIME_SECTION_WITH_LEN(str, len) do { debugf("[Section] %s\n", str); timings_start_section(&global_timings, make_string((u8 *)str, len)); } while (0)
+#define TIME_SECTION(str) do { debugf("[Section] %s\n", str); if (build_context.show_more_timings) timings_start_section(&global_timings, str_lit(str)); } while (0)
+#define TIME_SECTION_WITH_LEN(str, len) do { debugf("[Section] %s\n", str); if (build_context.show_more_timings) timings_start_section(&global_timings, make_string((u8 *)str, len)); } while (0)
enum TimingUnit {