2019-01-02 00:55:51 +00:00
|
|
|
/* SPDX-License-Identifier: MIT
|
2018-05-03 13:04:00 +00:00
|
|
|
*
|
2021-01-28 16:52:15 +00:00
|
|
|
* Copyright (C) 2017-2021 WireGuard LLC. All Rights Reserved.
|
2018-05-03 13:04:00 +00:00
|
|
|
*/
|
|
|
|
|
2019-03-03 03:04:41 +00:00
|
|
|
package device
|
2017-06-04 19:48:15 +00:00
|
|
|
|
2017-08-22 12:57:32 +00:00
|
|
|
import (
|
|
|
|
"sync/atomic"
|
2019-05-14 07:09:52 +00:00
|
|
|
|
|
|
|
"golang.zx2c4.com/wireguard/tun"
|
2017-08-22 12:57:32 +00:00
|
|
|
)
|
2017-07-15 14:27:59 +00:00
|
|
|
|
|
|
|
const DefaultMTU = 1420
|
|
|
|
|
2017-08-22 12:57:32 +00:00
|
|
|
func (device *Device) RoutineTUNEventReader() {
|
2018-02-11 22:26:54 +00:00
|
|
|
setUp := false
|
2021-01-26 22:05:48 +00:00
|
|
|
device.log.Verbosef("Routine: event worker - started")
|
2018-05-16 20:20:15 +00:00
|
|
|
|
2017-08-22 12:57:32 +00:00
|
|
|
for event := range device.tun.device.Events() {
|
2019-06-10 21:33:40 +00:00
|
|
|
if event&tun.EventMTUUpdate != 0 {
|
2017-08-22 12:57:32 +00:00
|
|
|
mtu, err := device.tun.device.MTU()
|
|
|
|
old := atomic.LoadInt32(&device.tun.mtu)
|
|
|
|
if err != nil {
|
2021-01-26 22:05:48 +00:00
|
|
|
device.log.Errorf("Failed to load updated MTU of device: %v", err)
|
2017-08-22 12:57:32 +00:00
|
|
|
} else if int(old) != mtu {
|
|
|
|
if mtu+MessageTransportSize > MaxMessageSize {
|
2021-01-26 22:05:48 +00:00
|
|
|
device.log.Verbosef("MTU updated: %v (too large)", mtu)
|
2017-08-22 12:57:32 +00:00
|
|
|
} else {
|
2021-01-26 22:05:48 +00:00
|
|
|
device.log.Verbosef("MTU updated: %v", mtu)
|
2017-08-22 12:57:32 +00:00
|
|
|
}
|
2017-08-22 15:22:45 +00:00
|
|
|
atomic.StoreInt32(&device.tun.mtu, int32(mtu))
|
2017-08-22 12:57:32 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-06-10 21:33:40 +00:00
|
|
|
if event&tun.EventUp != 0 && !setUp {
|
2021-01-26 22:05:48 +00:00
|
|
|
device.log.Verbosef("Interface set up")
|
2018-02-11 22:26:54 +00:00
|
|
|
setUp = true
|
2017-12-29 16:42:09 +00:00
|
|
|
device.Up()
|
2017-08-22 12:57:32 +00:00
|
|
|
}
|
|
|
|
|
2019-06-10 21:33:40 +00:00
|
|
|
if event&tun.EventDown != 0 && setUp {
|
2021-01-26 22:05:48 +00:00
|
|
|
device.log.Verbosef("Interface set down")
|
2018-02-11 22:26:54 +00:00
|
|
|
setUp = false
|
2018-01-13 08:00:37 +00:00
|
|
|
device.Down()
|
2017-08-22 12:57:32 +00:00
|
|
|
}
|
|
|
|
}
|
2018-05-16 20:20:15 +00:00
|
|
|
|
2021-01-26 22:05:48 +00:00
|
|
|
device.log.Verbosef("Routine: event worker - stopped")
|
2018-05-16 20:20:15 +00:00
|
|
|
device.state.stopping.Done()
|
2017-08-22 12:57:32 +00:00
|
|
|
}
|