summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--app/tools/libwg-go/Makefile4
-rw-r--r--app/tools/libwg-go/api-android.go15
m---------app/tools/wireguard0
m---------app/tools/wireguard-go0
4 files changed, 9 insertions, 10 deletions
diff --git a/app/tools/libwg-go/Makefile b/app/tools/libwg-go/Makefile
index 3daad830..a7828e79 100644
--- a/app/tools/libwg-go/Makefile
+++ b/app/tools/libwg-go/Makefile
@@ -2,9 +2,7 @@
#
# Copyright © 2018 Jason A. Donenfeld <Jason@zx2c4.com>. All Rights Reserved.
-containing = $(foreach v,$2,$(if $(findstring $1,$v),$v))
-FILES := $(wildcard ../wireguard-go/*/*.go) $(wildcard ../wireguard-go/*.go)
-FILES := $(filter-out %/main.go $(filter-out %_linux.go,$(call containing,_,$(FILES))),$(FILES))
+FILES := $(filter-out %/main.go,$(wildcard ../wireguard-go/*/*.go) $(wildcard ../wireguard-go/*.go))
NDK_GO_ARCH_MAP_x86 := 386
NDK_GO_ARCH_MAP_x86_64 := amd64
diff --git a/app/tools/libwg-go/api-android.go b/app/tools/libwg-go/api-android.go
index 63551512..5ea57a9d 100644
--- a/app/tools/libwg-go/api-android.go
+++ b/app/tools/libwg-go/api-android.go
@@ -10,13 +10,14 @@ package main
import "C"
import (
+ "./rwcancel"
"bufio"
+ "golang.org/x/sys/unix"
"io/ioutil"
"log"
"math"
"os"
"strings"
- "syscall"
)
type AndroidLogger struct {
@@ -52,21 +53,19 @@ func wgTurnOn(ifnameRef string, tun_fd int32, settings string) int32 {
events: make(chan TUNEvent, 5),
errors: make(chan error, 5),
nopi: true,
+ statusListenersShutdown: make(chan struct{}),
}
var err error
- err = syscall.SetNonblock(int(tun_fd), true)
- if err != nil {
- logger.Error.Println(err)
- return -1
- }
- tun.closingReader, tun.closingWriter, err = os.Pipe()
+ tun.fdCancel, err = rwcancel.NewRWCancel(int(tun_fd))
if err != nil {
+ unix.Close(int(tun_fd))
logger.Error.Println(err)
return -1
}
name, err := tun.Name()
if err != nil {
+ unix.Close(int(tun_fd))
logger.Error.Println(err)
return -1
}
@@ -77,6 +76,7 @@ func wgTurnOn(ifnameRef string, tun_fd int32, settings string) int32 {
bufferedSettings := bufio.NewReadWriter(bufio.NewReader(strings.NewReader(settings)), bufio.NewWriter(ioutil.Discard))
setError := ipcSetOperation(device, bufferedSettings)
if setError != nil {
+ unix.Close(int(tun_fd))
logger.Error.Println(setError)
return -1
}
@@ -91,6 +91,7 @@ func wgTurnOn(ifnameRef string, tun_fd int32, settings string) int32 {
}
}
if i == math.MaxInt32 {
+ unix.Close(int(tun_fd))
return -1
}
tunnelHandles[i] = device
diff --git a/app/tools/wireguard b/app/tools/wireguard
-Subproject 7cc2668355519ca78c6585197ed15f93b12891f
+Subproject 6b4a340f027d7978bb29cd7da672a20a0a07016
diff --git a/app/tools/wireguard-go b/app/tools/wireguard-go
-Subproject 233f079a9479279d2aab68f4accb139ee87ad66
+Subproject a62c770a99e830f220314d1bc779e8818d4ecc7