EtherGuard-VPN/conn/mark_unix.go

66 lines
1.1 KiB
Go
Raw Normal View History

// +build linux openbsd freebsd
2018-12-11 18:21:11 +01:00
2019-01-02 01:55:51 +01:00
/* SPDX-License-Identifier: MIT
2018-12-11 18:21:11 +01:00
*
* Copyright (C) 2017-2021 WireGuard LLC. All Rights Reserved.
2018-12-11 18:21:11 +01:00
*/
package conn
2018-12-11 18:21:11 +01:00
import (
"runtime"
2019-05-14 09:09:52 +02:00
"golang.org/x/sys/unix"
2018-12-11 18:21:11 +01:00
)
var fwmarkIoctl int
func init() {
switch runtime.GOOS {
case "linux", "android":
fwmarkIoctl = 36 /* unix.SO_MARK */
case "freebsd":
fwmarkIoctl = 0x1015 /* unix.SO_USER_COOKIE */
case "openbsd":
fwmarkIoctl = 0x1021 /* unix.SO_RTABLE */
}
}
func (bind *StdNetBind) SetMark(mark uint32) error {
var operr error
2018-12-11 18:21:11 +01:00
if fwmarkIoctl == 0 {
return nil
}
if bind.ipv4 != nil {
fd, err := bind.ipv4.SyscallConn()
if err != nil {
return err
}
err = fd.Control(func(fd uintptr) {
operr = unix.SetsockoptInt(int(fd), unix.SOL_SOCKET, fwmarkIoctl, int(mark))
2018-12-11 18:21:11 +01:00
})
if err == nil {
err = operr
}
2018-12-11 18:21:11 +01:00
if err != nil {
return err
}
}
if bind.ipv6 != nil {
fd, err := bind.ipv6.SyscallConn()
if err != nil {
return err
}
err = fd.Control(func(fd uintptr) {
operr = unix.SetsockoptInt(int(fd), unix.SOL_SOCKET, fwmarkIoctl, int(mark))
2018-12-11 18:21:11 +01:00
})
if err == nil {
err = operr
}
2018-12-11 18:21:11 +01:00
if err != nil {
return err
}
}
return nil
}