Commit 11084382 authored by Mitchell Hashimoto's avatar Mitchell Hashimoto

packer/rpc: cleaner way to keep the seq number in MuxConn high

parent da9f88ec
...@@ -163,6 +163,11 @@ func (m *MuxConn) openStream(id uint32) (*Stream, error) { ...@@ -163,6 +163,11 @@ func (m *MuxConn) openStream(id uint32) (*Stream, error) {
m.mu.Lock() m.mu.Lock()
defer m.mu.Unlock() defer m.mu.Unlock()
// Make sure we attempt to use the next biggest stream ID
if id >= m.curId {
m.curId = id + 1
}
// We have to check this again because there is a time period // We have to check this again because there is a time period
// above where we couldn't lost this lock. // above where we couldn't lost this lock.
if stream, ok := m.streams[id]; ok { if stream, ok := m.streams[id]; ok {
...@@ -302,12 +307,6 @@ func (m *MuxConn) loop() { ...@@ -302,12 +307,6 @@ func (m *MuxConn) loop() {
m.mu.Lock() m.mu.Lock()
delete(m.streams, stream.id) delete(m.streams, stream.id)
// Make sure we attempt to use the next biggest stream ID
if stream.id >= m.curId {
m.curId = stream.id + 1
}
m.mu.Unlock() m.mu.Unlock()
default: default:
log.Printf("[ERR] Fin received for stream %d in state: %d", id, stream.state) log.Printf("[ERR] Fin received for stream %d in state: %d", id, stream.state)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment