1
0
mirror of https://github.com/golang/go synced 2024-11-19 21:04:43 -07:00

net: don't set wrong option for controlling tcp keepalive on openbsd

Fixes #8679.

LGTM=iant
R=golang-codereviews, iant
CC=golang-codereviews
https://golang.org/cl/141730043
This commit is contained in:
Mikio Hara 2014-09-09 07:22:11 +09:00
parent 176020e1b1
commit 1fadd9e1ae

View File

@ -2,26 +2,15 @@
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
// TCP socket options for openbsd
package net
import (
"os"
"syscall"
"time"
)
// Set keep alive period.
func setKeepAlivePeriod(fd *netFD, d time.Duration) error {
if err := fd.incref(); err != nil {
return err
}
defer fd.decref()
// The kernel expects seconds so round to next highest second.
d += (time.Second - time.Nanosecond)
secs := int(d.Seconds())
return os.NewSyscallError("setsockopt", syscall.SetsockoptInt(fd.sysfd, syscall.IPPROTO_TCP, syscall.SO_KEEPALIVE, secs))
// OpenBSD has no user-settable per-socket TCP keepalive
// options.
return syscall.EPROTONOSUPPORT
}