2016-09-13 19:47:00 +00:00
|
|
|
// Copyright 2016 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 ipv6
|
|
|
|
|
|
|
|
import (
|
|
|
|
"os"
|
|
|
|
"unsafe"
|
|
|
|
|
|
|
|
"golang.org/x/net/bpf"
|
|
|
|
"golang.org/x/net/internal/netreflect"
|
|
|
|
)
|
|
|
|
|
|
|
|
// SetBPF attaches a BPF program to the connection.
|
|
|
|
//
|
|
|
|
// Only supported on Linux.
|
|
|
|
func (c *dgramOpt) SetBPF(filter []bpf.RawInstruction) error {
|
|
|
|
s, err := netreflect.PacketSocketOf(c.PacketConn)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2017-03-04 06:28:11 +00:00
|
|
|
prog := sockFProg{
|
2016-09-13 19:47:00 +00:00
|
|
|
Len: uint16(len(filter)),
|
2017-03-04 06:28:11 +00:00
|
|
|
Filter: (*sockFilter)(unsafe.Pointer(&filter[0])),
|
2016-09-13 19:47:00 +00:00
|
|
|
}
|
|
|
|
return os.NewSyscallError("setsockopt", setsockopt(s, sysSOL_SOCKET, sysSO_ATTACH_FILTER, unsafe.Pointer(&prog), uint32(unsafe.Sizeof(prog))))
|
|
|
|
}
|