Skip to content

Commit

Permalink
update
Browse files Browse the repository at this point in the history
  • Loading branch information
spiritLHLS committed May 1, 2024
1 parent 25fd3bc commit 96bc308
Show file tree
Hide file tree
Showing 4 changed files with 78 additions and 2 deletions.
2 changes: 0 additions & 2 deletions .github/workflows/main.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -87,8 +87,6 @@ jobs:
- goos: linux
goarch: arm
goarm: 5
- goos: android
goarch: arm64
- goos: windows
goarch: arm64
- goos: windows
Expand Down
26 changes: 26 additions & 0 deletions backtrace/listen_darwin.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
package backtrace

import (
"net"
"syscall"
)

func (t *Tracer) listen(network string, laddr *net.IPAddr) (*net.IPConn, error) {
conn, err := net.ListenIP(network, laddr)
if err != nil {
return nil, err
}
raw, err := conn.SyscallConn()
if err != nil {
conn.Close()
return nil, err
}
_ = raw.Control(func(fd uintptr) {
err = syscall.SetsockoptInt(int(fd), syscall.IPPROTO_IP, syscall.IP_HDRINCL, 1)
})
if err != nil {
conn.Close()
return nil, err
}
return conn, nil
}
26 changes: 26 additions & 0 deletions backtrace/listen_freebsd.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
package backtrace

import (
"net"
"syscall"
)

func (t *Tracer) listen(network string, laddr *net.IPAddr) (*net.IPConn, error) {
conn, err := net.ListenIP(network, laddr)
if err != nil {
return nil, err
}
raw, err := conn.SyscallConn()
if err != nil {
conn.Close()
return nil, err
}
_ = raw.Control(func(fd uintptr) {
err = syscall.SetsockoptInt(int(fd), syscall.IPPROTO_IP, syscall.IP_HDRINCL, 1)
})
if err != nil {
conn.Close()
return nil, err
}
return conn, nil
}
26 changes: 26 additions & 0 deletions backtrace/listen_openbsd.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
package backtrace

import (
"net"
"syscall"
)

func (t *Tracer) listen(network string, laddr *net.IPAddr) (*net.IPConn, error) {
conn, err := net.ListenIP(network, laddr)
if err != nil {
return nil, err
}
raw, err := conn.SyscallConn()
if err != nil {
conn.Close()
return nil, err
}
_ = raw.Control(func(fd uintptr) {
err = syscall.SetsockoptInt(int(fd), syscall.IPPROTO_IP, syscall.IP_HDRINCL, 1)
})
if err != nil {
conn.Close()
return nil, err
}
return conn, nil
}

0 comments on commit 96bc308

Please sign in to comment.