1
0
mirror of https://github.com/golang/go synced 2024-11-20 01:34:41 -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 // Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file. // license that can be found in the LICENSE file.
// TCP socket options for openbsd
package net package net
import ( import (
"os"
"syscall" "syscall"
"time" "time"
) )
// Set keep alive period.
func setKeepAlivePeriod(fd *netFD, d time.Duration) error { func setKeepAlivePeriod(fd *netFD, d time.Duration) error {
if err := fd.incref(); err != nil { // OpenBSD has no user-settable per-socket TCP keepalive
return err // options.
} return syscall.EPROTONOSUPPORT
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))
} }