diff --git a/doc/tinc.conf.5.in b/doc/tinc.conf.5.in index 5fee4034..7e066bb2 100644 --- a/doc/tinc.conf.5.in +++ b/doc/tinc.conf.5.in @@ -199,6 +199,7 @@ When disabled, calls tinc-up on startup, and tinc-down on shutdown. When enabled, .Nm tinc will only call tinc-up when at least one node is reachable, and will call tinc-down as soon as no nodes are reachable. +On Windows, this also determines when the virtual network interface "cable" is "plugged". .It Va DeviceType Li = Ar type Pq platform dependent The type of the virtual network device. Tinc will normally automatically select the right type of tun/tap interface, and this option should not be used. diff --git a/src/device.h b/src/device.h index 85112ffc..ad91a0e6 100644 --- a/src/device.h +++ b/src/device.h @@ -37,6 +37,8 @@ typedef struct devops_t { void (*close)(void); bool (*read)(struct vpn_packet_t *); bool (*write)(struct vpn_packet_t *); + void (*enable)(void); /* optional */ + void (*disable)(void); /* optional */ } devops_t; extern const devops_t os_devops; diff --git a/src/mingw/device.c b/src/mingw/device.c index 85c0c7b1..a765ce3b 100644 --- a/src/mingw/device.c +++ b/src/mingw/device.c @@ -94,7 +94,6 @@ static bool setup_device(void) { char adaptername[1024]; char tapname[1024]; DWORD len; - unsigned long status; bool found = false; @@ -200,11 +199,6 @@ static bool setup_device(void) { return false; } - /* Set media status for newer TAP-Win32 devices */ - - status = true; - DeviceIoControl(device_handle, TAP_IOCTL_SET_MEDIA_STATUS, &status, sizeof status, &status, sizeof status, &len, NULL); - device_info = "Windows tap device"; logger(DEBUG_ALWAYS, LOG_INFO, "%s (%s) is a %s", device, iface, device_info); @@ -212,6 +206,20 @@ static bool setup_device(void) { return true; } +static void enable_device(void) { + logger(DEBUG_ALWAYS, LOG_INFO, "Enabling %s", device_info); + ULONG status = 1; + DWORD len; + DeviceIoControl(device_handle, TAP_IOCTL_SET_MEDIA_STATUS, &status, sizeof status, &status, sizeof status, &len, NULL); +} + +static void disable_device(void) { + logger(DEBUG_ALWAYS, LOG_INFO, "Disabling %s", device_info); + ULONG status = 0; + DWORD len; + DeviceIoControl(device_handle, TAP_IOCTL_SET_MEDIA_STATUS, &status, sizeof status, &status, sizeof status, &len, NULL); +} + static void close_device(void) { CloseHandle(device_handle); device_handle = INVALID_HANDLE_VALUE; @@ -246,4 +254,6 @@ const devops_t os_devops = { .close = close_device, .read = read_packet, .write = write_packet, + .enable = enable_device, + .disable = disable_device, }; diff --git a/src/net_setup.c b/src/net_setup.c index 8c04d002..eec1711a 100644 --- a/src/net_setup.c +++ b/src/net_setup.c @@ -728,6 +728,9 @@ static bool add_listen_address(char *address, bool bindto) { } void device_enable(void) { + if (devops.enable) + devops.enable(); + /* Run tinc-up script to further initialize the tap interface */ char *envp[5] = {NULL}; @@ -753,6 +756,9 @@ void device_disable(void) { for(int i = 0; i < 4; i++) free(envp[i]); + + if (devops.disable) + devops.disable(); } /*