summaryrefslogtreecommitdiff
path: root/mark_unix.go
diff options
context:
space:
mode:
Diffstat (limited to 'mark_unix.go')
-rw-r--r--mark_unix.go64
1 files changed, 0 insertions, 64 deletions
diff --git a/mark_unix.go b/mark_unix.go
deleted file mode 100644
index 0ae62b7..0000000
--- a/mark_unix.go
+++ /dev/null
@@ -1,64 +0,0 @@
-// +build android openbsd freebsd
-
-/* SPDX-License-Identifier: MIT
- *
- * Copyright (C) 2017-2019 WireGuard LLC. All Rights Reserved.
- */
-
-package main
-
-import (
- "golang.org/x/sys/unix"
- "runtime"
-)
-
-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 *NativeBind) SetMark(mark uint32) error {
- var operr error
- 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))
- })
- if err == nil {
- err = operr
- }
- 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))
- })
- if err == nil {
- err = operr
- }
- if err != nil {
- return err
- }
- }
- return nil
-}