From 218ab479ffb6940479b710539db137e555b1f6de Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=9E=97=E5=BF=97=E5=AE=87?= Date: Fri, 10 May 2019 17:27:28 +1200 Subject: [PATCH] Fixed further race conditions. --- internal/httpauth/client.go | 2 +- pkg/messaging/link.go | 4 ---- 2 files changed, 1 insertion(+), 5 deletions(-) diff --git a/internal/httpauth/client.go b/internal/httpauth/client.go index 614034f99b..ae03201f46 100644 --- a/internal/httpauth/client.go +++ b/internal/httpauth/client.go @@ -137,7 +137,7 @@ func (c *Client) SetNonce(n Nonce) { } func (c *Client) getCurrentNonce() Nonce { - return Nonce(c.nonce) + return Nonce(atomic.LoadUint64(&c.nonce)) } func (c *Client) incrementNonce() { diff --git a/pkg/messaging/link.go b/pkg/messaging/link.go index c98aa5739b..57f4121d42 100644 --- a/pkg/messaging/link.go +++ b/pkg/messaging/link.go @@ -38,8 +38,6 @@ func DefaultLinkConfig() *LinkConfig { // Link represents a messaging connection in the perspective of an instance. type Link struct { rw io.ReadWriteCloser - rMx sync.Mutex - wMx sync.Mutex config *LinkConfig callbacks *Callbacks } @@ -174,9 +172,7 @@ func (c *Link) handleData(payload Frame, n int, err error) error { func (c *Link) writeFrame(t FrameType, body []byte) (int, error) { payload := MakeFrame(t, body) - c.wMx.Lock() n, err := WriteFrame(c.rw, payload) - c.wMx.Unlock() if err != nil { return 0, err }