| // Copyright 2017 The Go Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style |
| // license that can be found in the LICENSE file. |
| |
| // +build linux |
| // +build 386 amd64 arm arm64 |
| |
| package runtime_test |
| |
| import ( |
| "testing" |
| "time" |
| _ "unsafe" |
| ) |
| |
| // These tests are a little risky because they overwrite the vdsoClockgettimeSym value. |
| // It's normally initialized at startup and remains unchanged after that. |
| |
| //go:linkname vdsoClockgettimeSym runtime.vdsoClockgettimeSym |
| var vdsoClockgettimeSym uintptr |
| |
| func TestClockVDSOAndFallbackPaths(t *testing.T) { |
| // Check that we can call walltime() and nanotime() with and without their (1st) fast-paths. |
| // This just checks that fast and fallback paths can be called, rather than testing their |
| // results. |
| // |
| // Call them indirectly via time.Now(), so we don't need auxiliary .s files to allow us to |
| // use go:linkname to refer to the functions directly. |
| |
| save := vdsoClockgettimeSym |
| if save == 0 { |
| t.Log("vdsoClockgettime symbol not found; fallback path will be used by default") |
| } |
| |
| // Call with fast-path enabled (if vDSO symbol found at startup) |
| time.Now() |
| |
| // Call with fast-path disabled |
| vdsoClockgettimeSym = 0 |
| time.Now() |
| vdsoClockgettimeSym = save |
| } |
| |
| func BenchmarkClockVDSOAndFallbackPaths(b *testing.B) { |
| run := func(b *testing.B) { |
| for i := 0; i < b.N; i++ { |
| // Call via time.Now() - see comment in test above. |
| time.Now() |
| } |
| } |
| |
| save := vdsoClockgettimeSym |
| b.Run("vDSO", run) |
| vdsoClockgettimeSym = 0 |
| b.Run("Fallback", run) |
| vdsoClockgettimeSym = save |
| } |
| |
| func BenchmarkTimeNow(b *testing.B) { |
| for i := 0; i < b.N; i++ { |
| time.Now() |
| } |
| } |