wireguard-go/device/tun.go

56 lines
1.3 KiB
Go
Raw Normal View History

2019-01-02 00:55:51 +00:00
/* SPDX-License-Identifier: MIT
*
2019-01-02 00:55:51 +00:00
* Copyright (C) 2017-2019 WireGuard LLC. All Rights Reserved.
*/
2019-03-03 03:04:41 +00:00
package device
import (
2019-02-18 03:44:41 +00:00
"golang.zx2c4.com/wireguard/tun"
"sync/atomic"
)
const DefaultMTU = 1420
func (device *Device) RoutineTUNEventReader() {
setUp := false
logDebug := device.log.Debug
logInfo := device.log.Info
logError := device.log.Error
logDebug.Println("Routine: event worker - started")
device.state.starting.Done()
for event := range device.tun.device.Events() {
2018-05-23 00:10:54 +00:00
if event&tun.TUNEventMTUUpdate != 0 {
mtu, err := device.tun.device.MTU()
old := atomic.LoadInt32(&device.tun.mtu)
if err != nil {
logError.Println("Failed to load updated MTU of device:", err)
} else if int(old) != mtu {
if mtu+MessageTransportSize > MaxMessageSize {
logInfo.Println("MTU updated:", mtu, "(too large)")
} else {
logInfo.Println("MTU updated:", mtu)
}
2017-08-22 15:22:45 +00:00
atomic.StoreInt32(&device.tun.mtu, int32(mtu))
}
}
2018-05-23 00:10:54 +00:00
if event&tun.TUNEventUp != 0 && !setUp {
2017-12-29 16:42:09 +00:00
logInfo.Println("Interface set up")
setUp = true
2017-12-29 16:42:09 +00:00
device.Up()
}
2018-05-23 00:10:54 +00:00
if event&tun.TUNEventDown != 0 && setUp {
2017-12-29 16:42:09 +00:00
logInfo.Println("Interface set down")
setUp = false
device.Down()
}
}
logDebug.Println("Routine: event worker - stopped")
device.state.stopping.Done()
}