mirror of
https://github.com/kubernetes/sample-controller.git
synced 2025-01-22 09:52:52 +08:00
a2f289abf2
Automatic merge from submit-queue (batch tested with PRs 55798, 49579, 54862, 55188, 51990). If you want to cherry-pick this change to another branch, please follow the instructions <a href="https://github.com/kubernetes/community/blob/master/contributors/devel/cherry-picks.md">here</a>. Add monitoring support for hardware accelerators Currently only NVIDIA GPU monitoring is implemented. Feature repo issue: https://github.com/kubernetes/features/issues/369 cAdvisor PR: https://github.com/google/cadvisor/pull/1762 /kind feature /sig node /sig instrumentation /area hw-accelerators **Release note**: ```release-note Kubelet now exposes metrics for NVIDIA GPUs attached to the containers. ``` Kubernetes-commit: 779105673ab2f00af9e02dc9ac3c6413588aeae4
63 lines
1.9 KiB
Go
63 lines
1.9 KiB
Go
// 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 darwin dragonfly freebsd linux netbsd openbsd solaris
|
|
|
|
package unix
|
|
|
|
// TimespecToNsec converts a Timespec value into a number of
|
|
// nanoseconds since the Unix epoch.
|
|
func TimespecToNsec(ts Timespec) int64 { return int64(ts.Sec)*1e9 + int64(ts.Nsec) }
|
|
|
|
// NsecToTimespec takes a number of nanoseconds since the Unix epoch
|
|
// and returns the corresponding Timespec value.
|
|
func NsecToTimespec(nsec int64) Timespec {
|
|
sec := nsec / 1e9
|
|
nsec = nsec % 1e9
|
|
if nsec < 0 {
|
|
nsec += 1e9
|
|
sec--
|
|
}
|
|
return setTimespec(sec, nsec)
|
|
}
|
|
|
|
// TimevalToNsec converts a Timeval value into a number of nanoseconds
|
|
// since the Unix epoch.
|
|
func TimevalToNsec(tv Timeval) int64 { return int64(tv.Sec)*1e9 + int64(tv.Usec)*1e3 }
|
|
|
|
// NsecToTimeval takes a number of nanoseconds since the Unix epoch
|
|
// and returns the corresponding Timeval value.
|
|
func NsecToTimeval(nsec int64) Timeval {
|
|
nsec += 999 // round up to microsecond
|
|
usec := nsec % 1e9 / 1e3
|
|
sec := nsec / 1e9
|
|
if usec < 0 {
|
|
usec += 1e6
|
|
sec--
|
|
}
|
|
return setTimeval(sec, usec)
|
|
}
|
|
|
|
// Unix returns ts as the number of seconds and nanoseconds elapsed since the
|
|
// Unix epoch.
|
|
func (ts *Timespec) Unix() (sec int64, nsec int64) {
|
|
return int64(ts.Sec), int64(ts.Nsec)
|
|
}
|
|
|
|
// Unix returns tv as the number of seconds and nanoseconds elapsed since the
|
|
// Unix epoch.
|
|
func (tv *Timeval) Unix() (sec int64, nsec int64) {
|
|
return int64(tv.Sec), int64(tv.Usec) * 1000
|
|
}
|
|
|
|
// Nano returns ts as the number of nanoseconds elapsed since the Unix epoch.
|
|
func (ts *Timespec) Nano() int64 {
|
|
return int64(ts.Sec)*1e9 + int64(ts.Nsec)
|
|
}
|
|
|
|
// Nano returns tv as the number of nanoseconds elapsed since the Unix epoch.
|
|
func (tv *Timeval) Nano() int64 {
|
|
return int64(tv.Sec)*1e9 + int64(tv.Usec)*1000
|
|
}
|