Commit 499088f6 authored by Ian Lance Taylor's avatar Ian Lance Taylor

[release-branch.go1.12] internal/poll: fix deadlock in Write if len(buf) > maxRW

fd.l.Lock shouldn't be called in a loop.

Manual backport of CL 165598. It could not be cherry-picked due to conflicts.

Fixes #31211

Change-Id: Ib76e679f6a276b32fe9c1594b7e9a506017a7967
Reviewed-on: https://go-review.googlesource.com/c/go/+/170680
Run-TryBot: Ian Lance Taylor <iant@golang.org>
Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
parent 99158301
...@@ -660,6 +660,10 @@ func (fd *FD) Write(buf []byte) (int, error) { ...@@ -660,6 +660,10 @@ func (fd *FD) Write(buf []byte) (int, error) {
return 0, err return 0, err
} }
defer fd.writeUnlock() defer fd.writeUnlock()
if fd.isFile || fd.isDir || fd.isConsole {
fd.l.Lock()
defer fd.l.Unlock()
}
ntotal := 0 ntotal := 0
for len(buf) > 0 { for len(buf) > 0 {
...@@ -670,8 +674,6 @@ func (fd *FD) Write(buf []byte) (int, error) { ...@@ -670,8 +674,6 @@ func (fd *FD) Write(buf []byte) (int, error) {
var n int var n int
var err error var err error
if fd.isFile || fd.isDir || fd.isConsole { if fd.isFile || fd.isDir || fd.isConsole {
fd.l.Lock()
defer fd.l.Unlock()
if fd.isConsole { if fd.isConsole {
n, err = fd.writeConsole(b) n, err = fd.writeConsole(b)
} else { } else {
......
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