Commit 36a47f5b authored by Mitchell Hashimoto's avatar Mitchell Hashimoto

packer/rpc: more fine grained lock access on MuxConn

parent 5c683108
...@@ -61,23 +61,27 @@ func (m *MuxConn) Close() error { ...@@ -61,23 +61,27 @@ func (m *MuxConn) Close() error {
// point. In a real muxer, we'd probably want a handshake here. // point. In a real muxer, we'd probably want a handshake here.
func (m *MuxConn) Stream(id byte) (io.ReadWriteCloser, error) { func (m *MuxConn) Stream(id byte) (io.ReadWriteCloser, error) {
m.mu.Lock() m.mu.Lock()
defer m.mu.Unlock()
if _, ok := m.streams[id]; ok { if _, ok := m.streams[id]; ok {
m.mu.Unlock()
return nil, fmt.Errorf("Stream %d already exists", id) return nil, fmt.Errorf("Stream %d already exists", id)
} }
// Create the stream object and channel where data will be sent to // Create the stream object and channel where data will be sent to
dataR, dataW := io.Pipe() dataR, dataW := io.Pipe()
// Set the data channel so we can write to it.
m.streams[id] = dataW
// Unlock the lock so that the reader can access the stream writer.
m.mu.Unlock()
stream := &Stream{ stream := &Stream{
id: id, id: id,
mux: m, mux: m,
reader: dataR, reader: dataR,
} }
// Set the data channel so we can write to it.
m.streams[id] = dataW
return stream, nil return stream, nil
} }
......
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