aboutsummaryrefslogtreecommitdiffstats
path: root/tun/tun_windows.go
diff options
context:
space:
mode:
authorSimon Rozman <simon@rozman.si>2019-02-07 22:02:51 +0100
committerSimon Rozman <simon@rozman.si>2019-02-07 22:02:51 +0100
commitd87cbeeb2fb152b5f377758c68c655e09fe177f3 (patch)
tree1eb353b53e458b5b573fb2b2e552b15904ba5600 /tun/tun_windows.go
parentwintun: Clean excessive setupapi.DevInfo.GetDeviceInfoListDetail() call (diff)
downloadwireguard-go-d87cbeeb2fb152b5f377758c68c655e09fe177f3.tar.xz
wireguard-go-d87cbeeb2fb152b5f377758c68c655e09fe177f3.zip
wintun: Detect if a foreign interface with the same name exists
Signed-off-by: Simon Rozman <simon@rozman.si>
Diffstat (limited to 'tun/tun_windows.go')
-rw-r--r--tun/tun_windows.go16
1 files changed, 13 insertions, 3 deletions
diff --git a/tun/tun_windows.go b/tun/tun_windows.go
index 5f4f22a..5c231e7 100644
--- a/tun/tun_windows.go
+++ b/tun/tun_windows.go
@@ -55,16 +55,26 @@ type nativeTun struct {
func CreateTUN(ifname string) (TUNDevice, error) {
// Does an interface with this name already exist?
wt, err := wintun.GetInterface(ifname, 0)
- if wt == nil || err != nil {
+ if wt == nil {
// Interface does not exist or an error occured. Create one.
wt, _, err = wintun.CreateInterface("WireGuard Tunnel Adapter", 0)
if err != nil {
return nil, err
}
+ } else if err != nil {
+ // Foreign interface with the same name found.
+ // We could create a Wintun interface under a temporary name. But, should our
+ // proces die without deleting this interface first, the interface would remain
+ // orphaned.
+ return nil, err
+ }
- // Set interface name. (Ignore errors.)
- wt.SetInterfaceName(ifname)
+ err = wt.SetInterfaceName(ifname)
+ if err != nil {
+ wt.DeleteInterface(0)
+ return nil, err
}
+
err = wt.FlushInterface()
if err != nil {
wt.DeleteInterface(0)