mirror of https://github.com/ehang-io/nps
fix windows
parent
5e1b0be81c
commit
9b29bd64bd
|
@ -7,7 +7,6 @@ import (
|
||||||
"net"
|
"net"
|
||||||
"os"
|
"os"
|
||||||
"sync/atomic"
|
"sync/atomic"
|
||||||
"syscall"
|
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/astaxie/beego/logs"
|
"github.com/astaxie/beego/logs"
|
||||||
|
@ -64,26 +63,6 @@ func NewMux(c net.Conn, connType string) *Mux {
|
||||||
return m
|
return m
|
||||||
}
|
}
|
||||||
|
|
||||||
func getConnFd(c net.Conn) (fd *os.File, err error) {
|
|
||||||
switch c.(type) {
|
|
||||||
case *net.TCPConn:
|
|
||||||
fd, err = c.(*net.TCPConn).File()
|
|
||||||
if err != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
return
|
|
||||||
case *net.UDPConn:
|
|
||||||
fd, err = c.(*net.UDPConn).File()
|
|
||||||
if err != nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
return
|
|
||||||
default:
|
|
||||||
err = errors.New("mux:unknown conn type, only tcp or kcp")
|
|
||||||
return
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *Mux) NewConn() (*conn, error) {
|
func (s *Mux) NewConn() (*conn, error) {
|
||||||
if s.IsClose {
|
if s.IsClose {
|
||||||
return nil, errors.New("the mux has closed")
|
return nil, errors.New("the mux has closed")
|
||||||
|
@ -442,7 +421,7 @@ func (Self *bandwidth) SetCopySize(n uint16) {
|
||||||
|
|
||||||
func (Self *bandwidth) calcBandWidth() {
|
func (Self *bandwidth) calcBandWidth() {
|
||||||
t := Self.readStart.Sub(Self.lastReadStart)
|
t := Self.readStart.Sub(Self.lastReadStart)
|
||||||
bufferSize, err := syscall.GetsockoptInt(int(Self.fd.Fd()), syscall.SOL_SOCKET, syscall.SO_RCVBUF)
|
bufferSize, err := sysGetSock(Self.fd)
|
||||||
//logs.Warn(bufferSize)
|
//logs.Warn(bufferSize)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
logs.Warn(err)
|
logs.Warn(err)
|
||||||
|
@ -451,7 +430,7 @@ func (Self *bandwidth) calcBandWidth() {
|
||||||
}
|
}
|
||||||
if Self.bufLength >= uint32(bufferSize) {
|
if Self.bufLength >= uint32(bufferSize) {
|
||||||
atomic.StoreUint64(&Self.readBandwidth, math.Float64bits(float64(Self.bufLength)/t.Seconds()))
|
atomic.StoreUint64(&Self.readBandwidth, math.Float64bits(float64(Self.bufLength)/t.Seconds()))
|
||||||
// calculate the hole socket buffer, the time meaning to fill the buffer
|
// calculate the whole socket buffer, the time meaning to fill the buffer
|
||||||
//logs.Warn(Self.Get())
|
//logs.Warn(Self.Get())
|
||||||
} else {
|
} else {
|
||||||
Self.calcThreshold = uint32(bufferSize)
|
Self.calcThreshold = uint32(bufferSize)
|
||||||
|
|
|
@ -0,0 +1,34 @@
|
||||||
|
// +build !windows
|
||||||
|
|
||||||
|
package mux
|
||||||
|
|
||||||
|
import (
|
||||||
|
"errors"
|
||||||
|
"net"
|
||||||
|
"os"
|
||||||
|
"syscall"
|
||||||
|
)
|
||||||
|
|
||||||
|
func sysGetSock(fd *os.File) (bufferSize int, err error) {
|
||||||
|
return syscall.GetsockoptInt(int(fd.Fd()), syscall.SOL_SOCKET, syscall.SO_RCVBUF)
|
||||||
|
}
|
||||||
|
|
||||||
|
func getConnFd(c net.Conn) (fd *os.File, err error) {
|
||||||
|
switch c.(type) {
|
||||||
|
case *net.TCPConn:
|
||||||
|
fd, err = c.(*net.TCPConn).File()
|
||||||
|
if err != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
return
|
||||||
|
case *net.UDPConn:
|
||||||
|
fd, err = c.(*net.UDPConn).File()
|
||||||
|
if err != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
return
|
||||||
|
default:
|
||||||
|
err = errors.New("mux:unknown conn type, only tcp or kcp")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,37 @@
|
||||||
|
// +build windows
|
||||||
|
|
||||||
|
package mux
|
||||||
|
|
||||||
|
import (
|
||||||
|
"errors"
|
||||||
|
"net"
|
||||||
|
"os"
|
||||||
|
)
|
||||||
|
|
||||||
|
func sysGetSock(fd *os.File) (bufferSize int, err error) {
|
||||||
|
// https://github.com/golang/sys/blob/master/windows/syscall_windows.go#L1184
|
||||||
|
// not support, WTF???
|
||||||
|
// return syscall.GetsockoptInt((syscall.Handle)(unsafe.Pointer(fd.Fd())), syscall.SOL_SOCKET, syscall.SO_RCVBUF)
|
||||||
|
bufferSize = 10 * 1024 * 1024
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
func getConnFd(c net.Conn) (fd *os.File, err error) {
|
||||||
|
switch c.(type) {
|
||||||
|
case *net.TCPConn:
|
||||||
|
//fd, err = c.(*net.TCPConn).File()
|
||||||
|
//if err != nil {
|
||||||
|
// return
|
||||||
|
//}
|
||||||
|
return
|
||||||
|
case *net.UDPConn:
|
||||||
|
//fd, err = c.(*net.UDPConn).File()
|
||||||
|
//if err != nil {
|
||||||
|
// return
|
||||||
|
//}
|
||||||
|
return
|
||||||
|
default:
|
||||||
|
err = errors.New("mux:unknown conn type, only tcp or kcp")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue