mirror of
https://github.com/SagerNet/sing-tun.git
synced 2025-04-04 12:27:39 +03:00
Fix darwin monitor
This commit is contained in:
parent
e8633c66d2
commit
8d285f70fb
2 changed files with 16 additions and 4 deletions
|
@ -170,6 +170,8 @@ func getDefaultInterfaceBySocket() (*net.Interface, error) {
|
||||||
Port: 80,
|
Port: 80,
|
||||||
})
|
})
|
||||||
result := make(chan netip.Addr, 1)
|
result := make(chan netip.Addr, 1)
|
||||||
|
done := make(chan struct{})
|
||||||
|
defer close(done)
|
||||||
go func() {
|
go func() {
|
||||||
for {
|
for {
|
||||||
sockname, sockErr := unix.Getsockname(socketFd)
|
sockname, sockErr := unix.Getsockname(socketFd)
|
||||||
|
@ -182,8 +184,13 @@ func getDefaultInterfaceBySocket() (*net.Interface, error) {
|
||||||
}
|
}
|
||||||
addr := netip.AddrFrom4(sockaddr.Addr)
|
addr := netip.AddrFrom4(sockaddr.Addr)
|
||||||
if addr.IsUnspecified() {
|
if addr.IsUnspecified() {
|
||||||
time.Sleep(time.Millisecond)
|
select {
|
||||||
continue
|
case <-done:
|
||||||
|
break
|
||||||
|
default:
|
||||||
|
time.Sleep(10 * time.Millisecond)
|
||||||
|
continue
|
||||||
|
}
|
||||||
}
|
}
|
||||||
result <- addr
|
result <- addr
|
||||||
break
|
break
|
||||||
|
@ -193,7 +200,7 @@ func getDefaultInterfaceBySocket() (*net.Interface, error) {
|
||||||
select {
|
select {
|
||||||
case selectedAddr = <-result:
|
case selectedAddr = <-result:
|
||||||
case <-time.After(time.Second):
|
case <-time.After(time.Second):
|
||||||
return nil, os.ErrDeadlineExceeded
|
return nil, nil
|
||||||
}
|
}
|
||||||
interfaces, err := net.Interfaces()
|
interfaces, err := net.Interfaces()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|
|
@ -6,6 +6,7 @@ import (
|
||||||
"errors"
|
"errors"
|
||||||
"net"
|
"net"
|
||||||
"net/netip"
|
"net/netip"
|
||||||
|
"runtime"
|
||||||
"sync"
|
"sync"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
@ -71,7 +72,9 @@ func (m *defaultInterfaceMonitor) Start() error {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *defaultInterfaceMonitor) delayCheckUpdate() {
|
func (m *defaultInterfaceMonitor) delayCheckUpdate() {
|
||||||
time.Sleep(time.Second)
|
if runtime.GOOS == "android" {
|
||||||
|
time.Sleep(time.Second)
|
||||||
|
}
|
||||||
err := m.updateInterfaces()
|
err := m.updateInterfaces()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
m.logger.Error("update interfaces: ", err)
|
m.logger.Error("update interfaces: ", err)
|
||||||
|
@ -81,6 +84,8 @@ func (m *defaultInterfaceMonitor) delayCheckUpdate() {
|
||||||
m.defaultInterfaceName = ""
|
m.defaultInterfaceName = ""
|
||||||
m.defaultInterfaceIndex = -1
|
m.defaultInterfaceIndex = -1
|
||||||
m.emit(EventNoRoute)
|
m.emit(EventNoRoute)
|
||||||
|
} else if err != nil {
|
||||||
|
m.logger.Error("check interface: ", err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue