83 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			83 lines
		
	
	
		
			2.5 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 aix darwin dragonfly freebsd linux netbsd openbsd solaris
 | |
| 
 | |
| package unix
 | |
| 
 | |
| import "time"
 | |
| 
 | |
| // 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)
 | |
| }
 | |
| 
 | |
| // TimeToTimespec converts t into a Timespec.
 | |
| // On some 32-bit systems the range of valid Timespec values are smaller
 | |
| // than that of time.Time values.  So if t is out of the valid range of
 | |
| // Timespec, it returns a zero Timespec and ERANGE.
 | |
| func TimeToTimespec(t time.Time) (Timespec, error) {
 | |
| 	sec := t.Unix()
 | |
| 	nsec := int64(t.Nanosecond())
 | |
| 	ts := setTimespec(sec, nsec)
 | |
| 
 | |
| 	// Currently all targets have either int32 or int64 for Timespec.Sec.
 | |
| 	// If there were a new target with floating point type for it, we have
 | |
| 	// to consider the rounding error.
 | |
| 	if int64(ts.Sec) != sec {
 | |
| 		return Timespec{}, ERANGE
 | |
| 	}
 | |
| 	return ts, nil
 | |
| }
 | |
| 
 | |
| // 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
 | |
| }
 |