|  | // 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 ppc64 ppc64le | 
|  |  | 
|  | 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() | 
|  | } | 
|  | } |