go/src
Daulet Zhanguzin 27c3814275 io: correctly process result of sendfile(2) when src returns 0 bytes
Fixes #53658. io.Copy() uses sendfile(2) to avoid allocating extra buffers when src is a file and dst is a TCPConn. However if src returns no bytes current logic treats it as failure and falls back to copying via user space. The following is a benchmark that illustrates the bug.

Benchmark: https://go.dev/play/p/zgZwpjUatSq

Before:
BenchmarkCopy-16          541006              2137 ns/op            4077 B/op          0 allocs/op

After:
BenchmarkCopy-16          490383              2365 ns/op             174 B/op          8 allocs/op

Change-Id: I703376d53b20e080c6204a73c96867cce16b24cf
GitHub-Last-Rev: 3a50be4f16
GitHub-Pull-Request: golang/go#53659
Reviewed-on: https://go-review.googlesource.com/c/go/+/415834
TryBot-Result: Gopher Robot <gobot@golang.org>
Reviewed-by: Michael Knyszek <mknyszek@google.com>
Run-TryBot: Ian Lance Taylor <iant@google.com>
Auto-Submit: Ian Lance Taylor <iant@google.com>
Reviewed-by: Ian Lance Taylor <iant@google.com>
2022-11-09 03:01:33 +00:00
..
archive archive/tar: limit size of headers 2022-10-05 20:40:43 +00:00
arena arena: add experimental arena package 2022-10-12 20:23:36 +00:00
bufio
builtin
bytes
cmd cmd/compile: fix transitive inlining of generic functions 2022-11-08 21:26:09 +00:00
compress compress: remove useless break statement 2022-09-29 22:59:14 +00:00
container
context context: add APIs for writing and reading cancelation cause 2022-11-08 13:51:16 +00:00
crypto crypto/tls: use certificate cache in client 2022-11-07 19:47:10 +00:00
database/sql
debug all: fix comment typos 2022-11-05 21:02:45 +00:00
embed
encoding encoding/xml: error when closing tag does not match opening tag 2022-11-09 03:01:28 +00:00
errors errors: add test for Join 2022-10-17 21:48:12 +00:00
expvar
flag flag: clarify that the main func at pkg.go.dev is part of a testing suite 2022-10-26 18:59:00 +00:00
fmt
go all: fix comment typos 2022-11-05 21:02:45 +00:00
hash hash/crc64: use slicing by 8 when the size is greater or equal than 2k 2022-10-27 16:52:41 +00:00
html
image all: fix a few function names on comments 2022-11-03 15:17:11 +00:00
index/suffixarray
internal io: correctly process result of sendfile(2) when src returns 0 bytes 2022-11-09 03:01:33 +00:00
io
log log/syslog: return nil directly 2022-10-03 08:59:45 +00:00
math math/big: remove underscores from Binomial docs 2022-11-08 05:24:43 +00:00
mime
net io: correctly process result of sendfile(2) when src returns 0 bytes 2022-11-09 03:01:33 +00:00
os all: fix function names in comments 2022-11-04 22:36:12 +00:00
path
plugin
reflect reflect: use unsafe.String in name.name and name.tag 2022-11-08 18:33:21 +00:00
regexp regexp: add ErrLarge error 2022-11-02 18:15:21 +00:00
runtime runtime internal/cpu: rename "Zeus" "NeoverseV1". 2022-11-08 23:11:32 +00:00
sort
strconv all: remove uses of rand.Seed 2022-10-26 16:24:57 +00:00
strings internal/bytealg: fix bug in index function for ppc64le/power9 2022-10-31 12:52:07 +00:00
sync sync/atomic: disallow type conversions of atomic.Pointer[T] 2022-11-07 21:25:12 +00:00
syscall syscall, os/exec: reject environment variables containing NULs 2022-11-01 16:40:37 +00:00
testdata
testing testing: Document RunParallel ns/op behavior 2022-11-07 10:44:33 +00:00
text all: fix function names in comments 2022-11-04 22:36:12 +00:00
time time: optimize appendInt and appendNanos 2022-10-24 19:23:32 +00:00
unicode
unsafe
vendor all: update golang.org/x/tools to 8166dca1ce 2022-10-26 00:11:50 +00:00
Make.dist
README.vendor
all.bash
all.bat
all.rc
bootstrap.bash
buildall.bash all: use grep -E/-F instead of fgrep/egrep 2022-10-06 21:22:22 +00:00
clean.bash
clean.bat
clean.rc
cmp.bash
go.mod all: update golang.org/x/tools to 8166dca1ce 2022-10-26 00:11:50 +00:00
go.sum all: update golang.org/x/tools to 8166dca1ce 2022-10-26 00:11:50 +00:00
make.bash all: use Go 1.17.13 for bootstrap 2022-10-17 19:46:59 +00:00
make.bat all: use Go 1.17.13 for bootstrap 2022-10-17 19:46:59 +00:00
make.rc all: use Go 1.17.13 for bootstrap 2022-10-17 19:46:59 +00:00
race.bash
race.bat
run.bash
run.bat
run.rc

README.vendor

Vendoring in std and cmd
========================

The Go command maintains copies of external packages needed by the
standard library in the src/vendor and src/cmd/vendor directories.

In GOPATH mode, imports of vendored packages are resolved to these
directories following normal vendor directory logic
(see golang.org/s/go15vendor).

In module mode, std and cmd are modules (defined in src/go.mod and
src/cmd/go.mod). When a package outside std or cmd is imported
by a package inside std or cmd, the import path is interpreted
as if it had a "vendor/" prefix. For example, within "crypto/tls",
an import of "golang.org/x/crypto/cryptobyte" resolves to
"vendor/golang.org/x/crypto/cryptobyte". When a package with the
same path is imported from a package outside std or cmd, it will
be resolved normally. Consequently, a binary may be built with two
copies of a package at different versions if the package is
imported normally and vendored by the standard library.

Vendored packages are internally renamed with a "vendor/" prefix
to preserve the invariant that all packages have distinct paths.
This is necessary to avoid compiler and linker conflicts. Adding
a "vendor/" prefix also maintains the invariant that standard
library packages begin with a dotless path element.

The module requirements of std and cmd do not influence version
selection in other modules. They are only considered when running
module commands like 'go get' and 'go mod vendor' from a directory
in GOROOT/src.

Maintaining vendor directories
==============================

Before updating vendor directories, ensure that module mode is enabled.
Make sure GO111MODULE=off is not set ('on' or 'auto' should work).

Requirements may be added, updated, and removed with 'go get'.
The vendor directory may be updated with 'go mod vendor'.
A typical sequence might be:

    cd src
    go get -d golang.org/x/net@latest
    go mod tidy
    go mod vendor

Use caution when passing '-u' to 'go get'. The '-u' flag updates
modules providing all transitively imported packages, not only
the module providing the target package.

Note that 'go mod vendor' only copies packages that are transitively
imported by packages in the current module. If a new package is needed,
it should be imported before running 'go mod vendor'.