wgengine/monitor: close closeHandle

eccc167 introduced closeHandle which opened the handle,
but never closed it.

Windows handles should be closed.

Updates #921

Signed-off-by: Alex Brainman <alex.brainman@gmail.com>
This commit is contained in:
Alex Brainman 2020-11-22 10:28:10 +11:00 committed by Brad Fitzpatrick
parent 83fccf9fe5
commit 9985b3f1ed

View File

@ -51,13 +51,14 @@ type messageOrError struct {
} }
type winMon struct { type winMon struct {
ctx context.Context ctx context.Context
cancel context.CancelFunc cancel context.CancelFunc
messagec chan messageOrError messagec chan messageOrError
logf logger.Logf logf logger.Logf
pollTicker *time.Ticker pollTicker *time.Ticker
lastState *interfaces.State lastState *interfaces.State
closeHandle windows.Handle // signaled upon close closeHandle windows.Handle // signaled upon close
goroutineDoneCh chan struct{} // closed when awaitIPAndRouteChanges goroutine has stopped
mu sync.Mutex mu sync.Mutex
lastNetChange time.Time lastNetChange time.Time
@ -72,12 +73,13 @@ func newOSMon(logf logger.Logf) (osMon, error) {
ctx, cancel := context.WithCancel(context.Background()) ctx, cancel := context.WithCancel(context.Background())
m := &winMon{ m := &winMon{
logf: logf, logf: logf,
ctx: ctx, ctx: ctx,
cancel: cancel, cancel: cancel,
messagec: make(chan messageOrError, 1), messagec: make(chan messageOrError, 1),
pollTicker: time.NewTicker(pollIntervalSlow), pollTicker: time.NewTicker(pollIntervalSlow),
closeHandle: closeHandle, closeHandle: closeHandle,
goroutineDoneCh: make(chan struct{}),
} }
go m.awaitIPAndRouteChanges() go m.awaitIPAndRouteChanges()
return m, nil return m, nil
@ -87,6 +89,12 @@ func (m *winMon) Close() error {
m.cancel() m.cancel()
m.pollTicker.Stop() m.pollTicker.Stop()
windows.SetEvent(m.closeHandle) // wakes up any reader blocked in Receive windows.SetEvent(m.closeHandle) // wakes up any reader blocked in Receive
// Wait for awaitIPAndRouteChannges to be done, which could
// still be using the m.closeHandle.
<-m.goroutineDoneCh
windows.CloseHandle(m.closeHandle)
return nil return nil
} }
@ -125,6 +133,7 @@ func (m *winMon) stateChanged() bool {
} }
func (m *winMon) awaitIPAndRouteChanges() { func (m *winMon) awaitIPAndRouteChanges() {
defer close(m.goroutineDoneCh)
for { for {
msg, err := m.getIPOrRouteChangeMessage() msg, err := m.getIPOrRouteChangeMessage()
if err == errClosed { if err == errClosed {