mirror of
https://github.com/golang/go
synced 2024-11-06 15:36:24 -07:00
38543c2813
This slightly simplified the code. I stumbled upon this when support was being added to Fuchsia (and this pattern was initially cargo-culted). Change-Id: Ica090a118a0056c5c1b51697691bc7308f0d424a Reviewed-on: https://go-review.googlesource.com/c/go/+/177878 Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org> Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org> TryBot-Result: Gobot Gobot <gobot@golang.org>
24 lines
698 B
Go
24 lines
698 B
Go
// Copyright 2009 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.
|
|
|
|
package net
|
|
|
|
import (
|
|
"runtime"
|
|
"syscall"
|
|
"time"
|
|
)
|
|
|
|
func setKeepAlivePeriod(fd *netFD, d time.Duration) error {
|
|
// The kernel expects milliseconds so round to next highest
|
|
// millisecond.
|
|
msecs := int(roundDurationUp(d, time.Millisecond))
|
|
if err := fd.pfd.SetsockoptInt(syscall.IPPROTO_TCP, syscall.TCP_KEEPINTVL, msecs); err != nil {
|
|
return wrapSyscallError("setsockopt", err)
|
|
}
|
|
err := fd.pfd.SetsockoptInt(syscall.IPPROTO_TCP, syscall.TCP_KEEPIDLE, msecs)
|
|
runtime.KeepAlive(fd)
|
|
return wrapSyscallError("setsockopt", err)
|
|
}
|