mirror of
https://github.com/golang/go
synced 2024-10-05 11:41:22 -06:00
db8d5b7608
Unfortunately Oracle Solaris does not have TCP_KEEPIDLE and TCP_KEEPINTVL. TCP_KEEPIDLE is equivalent to TCP_KEEPALIVE_THRESHOLD, but TCP_KEEPINTVL does not have a direct equivalent, so we don't set TCP_KEEPINTVL any more. Old Darwin versions also lack TCP_KEEPINTVL, but the code tries to set it anyway so that it works on newer versions. We can't do that because Oracle might assign the number illumos uses for TCP_KEEPINTVL to a constant with a different meaning. Unfortunately there's nothing we can do if we want to support both illumos and Oracle Solaris with the same GOOS. Updates #9614. Change-Id: Id39eb5147f7afa8e951f886c0bf529d00f0e1bd4 Reviewed-on: https://go-review.googlesource.com/7690 Reviewed-by: Minux Ma <minux@golang.org> Reviewed-by: Mikio Hara <mikioh.mikioh@gmail.com>
36 lines
1.2 KiB
Go
36 lines
1.2 KiB
Go
// Copyright 2015 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 (
|
|
"os"
|
|
"syscall"
|
|
"time"
|
|
)
|
|
|
|
func setKeepAlivePeriod(fd *netFD, d time.Duration) error {
|
|
if err := fd.incref(); err != nil {
|
|
return err
|
|
}
|
|
defer fd.decref()
|
|
// The kernel expects milliseconds so round to next highest
|
|
// millisecond.
|
|
d += (time.Millisecond - time.Nanosecond)
|
|
msecs := int(d / time.Millisecond)
|
|
|
|
// Normally we'd do
|
|
// syscall.SetsockoptInt(fd.sysfd, syscall.IPPROTO_TCP, syscall.TCP_KEEPINTVL, secs)
|
|
// here, but we can't because Solaris does not have TCP_KEEPINTVL.
|
|
// Solaris has TCP_KEEPALIVE_ABORT_THRESHOLD, but it's not the same
|
|
// thing, it refers to the total time until aborting (not between
|
|
// probes), and it uses an exponential backoff algorithm instead of
|
|
// waiting the same time between probes. We can't hope for the best
|
|
// and do it anyway, like on Darwin, because Solaris might eventually
|
|
// allocate a constant with a different meaning for the value of
|
|
// TCP_KEEPINTVL on illumos.
|
|
|
|
return os.NewSyscallError("setsockopt", syscall.SetsockoptInt(fd.sysfd, syscall.IPPROTO_TCP, syscall.TCP_KEEPALIVE_THRESHOLD, msecs))
|
|
}
|