Skip to content

Commit

Permalink
Improve: recycle buffer after packet used
Browse files Browse the repository at this point in the history
  • Loading branch information
Dreamacro committed Apr 16, 2020
1 parent 2750c7e commit 1825535
Show file tree
Hide file tree
Showing 6 changed files with 27 additions and 29 deletions.
4 changes: 2 additions & 2 deletions constant/adapters.go
Original file line number Diff line number Diff line change
Expand Up @@ -135,8 +135,8 @@ type UDPPacket interface {
// this is important when using Fake-IP.
WriteBack(b []byte, addr net.Addr) (n int, err error)

// Close closes the underlaying connection.
Close() error
// Drop call after packet is used, could recycle buffer in this function.
Drop()

// LocalAddr returns the source IP/Port of packet
LocalAddr() net.Addr
Expand Down
9 changes: 4 additions & 5 deletions proxy/redir/udp.go
Original file line number Diff line number Diff line change
Expand Up @@ -66,10 +66,9 @@ func (l *RedirUDPListener) Address() string {

func handleRedirUDP(pc net.PacketConn, buf []byte, lAddr *net.UDPAddr, rAddr *net.UDPAddr) {
target := socks5.ParseAddrToSocksAddr(rAddr)
packet := &fakeConn{
PacketConn: pc,
lAddr: lAddr,
buf: buf,
pkt := &packet{
lAddr: lAddr,
buf: buf,
}
tunnel.AddPacket(adapters.NewPacket(target, packet, C.REDIR))
tunnel.AddPacket(adapters.NewPacket(target, pkt, C.REDIR))
}
14 changes: 6 additions & 8 deletions proxy/redir/utils.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,18 +6,17 @@ import (
"github.com/Dreamacro/clash/common/pool"
)

type fakeConn struct {
net.PacketConn
type packet struct {
lAddr *net.UDPAddr
buf []byte
}

func (c *fakeConn) Data() []byte {
func (c *packet) Data() []byte {
return c.buf
}

// WriteBack opens a new socket binding `addr` to wirte UDP packet back
func (c *fakeConn) WriteBack(b []byte, addr net.Addr) (n int, err error) {
func (c *packet) WriteBack(b []byte, addr net.Addr) (n int, err error) {
tc, err := dialUDP("udp", addr.(*net.UDPAddr), c.lAddr)
if err != nil {
n = 0
Expand All @@ -29,12 +28,11 @@ func (c *fakeConn) WriteBack(b []byte, addr net.Addr) (n int, err error) {
}

// LocalAddr returns the source IP/Port of UDP Packet
func (c *fakeConn) LocalAddr() net.Addr {
func (c *packet) LocalAddr() net.Addr {
return c.lAddr
}

func (c *fakeConn) Close() error {
err := c.PacketConn.Close()
func (c *packet) Drop() {
pool.BufPool.Put(c.buf[:cap(c.buf)])
return err
return
}
10 changes: 5 additions & 5 deletions proxy/socks/udp.go
Original file line number Diff line number Diff line change
Expand Up @@ -63,11 +63,11 @@ func handleSocksUDP(pc net.PacketConn, buf []byte, addr net.Addr) {
pool.BufPool.Put(buf[:cap(buf)])
return
}
packet := &fakeConn{
PacketConn: pc,
rAddr: addr,
payload: payload,
bufRef: buf,
packet := &packet{
pc: pc,
rAddr: addr,
payload: payload,
bufRef: buf,
}
tunnel.AddPacket(adapters.NewPacket(target, packet, C.SOCKS))
}
17 changes: 8 additions & 9 deletions proxy/socks/utils.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,33 +7,32 @@ import (
"github.com/Dreamacro/clash/component/socks5"
)

type fakeConn struct {
net.PacketConn
type packet struct {
pc net.PacketConn
rAddr net.Addr
payload []byte
bufRef []byte
}

func (c *fakeConn) Data() []byte {
func (c *packet) Data() []byte {
return c.payload
}

// WriteBack wirtes UDP packet with source(ip, port) = `addr`
func (c *fakeConn) WriteBack(b []byte, addr net.Addr) (n int, err error) {
func (c *packet) WriteBack(b []byte, addr net.Addr) (n int, err error) {
packet, err := socks5.EncodeUDPPacket(socks5.ParseAddrToSocksAddr(addr), b)
if err != nil {
return
}
return c.PacketConn.WriteTo(packet, c.rAddr)
return c.pc.WriteTo(packet, c.rAddr)
}

// LocalAddr returns the source IP/Port of UDP Packet
func (c *fakeConn) LocalAddr() net.Addr {
func (c *packet) LocalAddr() net.Addr {
return c.rAddr
}

func (c *fakeConn) Close() error {
err := c.PacketConn.Close()
func (c *packet) Drop() {
pool.BufPool.Put(c.bufRef[:cap(c.bufRef)])
return err
return
}
2 changes: 2 additions & 0 deletions tunnel/connection.go
Original file line number Diff line number Diff line change
Expand Up @@ -82,6 +82,8 @@ func handleHTTP(request *adapters.HTTPAdapter, outbound net.Conn) {
}

func handleUDPToRemote(packet C.UDPPacket, pc C.PacketConn, metadata *C.Metadata) {
defer packet.Drop()

if _, err := pc.WriteWithMetadata(packet.Data(), metadata); err != nil {
return
}
Expand Down

0 comments on commit 1825535

Please sign in to comment.