X-Git-Url: https://www.tinc-vpn.org/git/browse?p=tinc;a=blobdiff_plain;f=src%2Flinux%2Fdevice.c;h=5ae89478c44254e36ca25c05e147259ad108c6db;hp=f50ff1123be023261f23ac52deed8063309f906f;hb=0a84f9cb8f52f2d2b4f03a5ad5ef9dfcd3509033;hpb=708314df2f61675d0f54e541c9fff62ac1f433b5 diff --git a/src/linux/device.c b/src/linux/device.c index f50ff112..5ae89478 100644 --- a/src/linux/device.c +++ b/src/linux/device.c @@ -45,6 +45,7 @@ int device_fd = -1; static device_type_t device_type; char *device = NULL; char *iface = NULL; +static char *type = NULL; static char ifrname[IFNAMSIZ]; static char *device_info; @@ -80,7 +81,15 @@ static bool setup_device(void) { /* Ok now check if this is an old ethertap or a new tun/tap thingie */ memset(&ifr, 0, sizeof(ifr)); - if(routing_mode == RMODE_ROUTER) { + + get_config_string(lookup_config(config_tree, "DeviceType"), &type); + + if(type && strcasecmp(type, "tun") && strcasecmp(type, "tap")) { + logger(LOG_ERR, "Unknown device type %s!", type); + return false; + } + + if((type && !strcasecmp(type, "tun")) || (!type && routing_mode == RMODE_ROUTER)) { ifr.ifr_flags = IFF_TUN; device_type = DEVICE_TYPE_TUN; device_info = "Linux tun/tap device (tun mode)"; @@ -128,6 +137,7 @@ static bool setup_device(void) { static void close_device(void) { close(device_fd); + free(type); free(device); free(iface); } @@ -200,7 +210,7 @@ static bool write_packet(vpn_packet_t *packet) { } break; case DEVICE_TYPE_ETHERTAP: - *(short int *)(packet->data - 2) = packet->len; + memcpy(packet->data - 2, &packet->len, 2); if(write(device_fd, packet->data - 2, packet->len + 2) < 0) { logger(LOG_ERR, "Can't write to %s %s: %s", device_info, device,