go/src
Filippo Valsorda 0a5ca2422f crypto/ecdsa: draw a fixed amount of entropy while signing
The current code, introduced in CL 2422, mixes K bits of entropy with
the private key and message digest to generate the signature nonce,
where K is half the bit size of the curve. While the ECDLP complexity
(and hence security level) of a curve is half its bit size, the birthday
bound on K bits is only K/2. For P-224, this means we should expect a
collision after 2^56 signatures over the same message with the same key.

A collision, which is unlikely, would still not be a major practical
concern, because the scheme would fall back to a secure deterministic
signature scheme, and simply leak the fact that the two signed messages
are the same (which is presumably already public).

Still, we can simplify the code and remove the eventuality by always
drawing 256 bits of entropy.

Change-Id: I58097bd3cfc9283503e38751c924c53d271af92b
Reviewed-on: https://go-review.googlesource.com/c/go/+/352530
Trust: Filippo Valsorda <filippo@golang.org>
Run-TryBot: Filippo Valsorda <filippo@golang.org>
TryBot-Result: Go Bot <gobot@golang.org>
Reviewed-by: Roland Shoemaker <roland@golang.org>
2021-11-05 04:20:33 +00:00
..
archive archive/zip: don't panic on (*Reader).Open 2021-11-02 20:47:30 +00:00
bufio bufio: use underlying ReadFrom even when data is buffered 2021-10-18 21:52:05 +00:00
builtin
bytes bytes: test for page boundary crosses on sep of Index 2021-11-02 17:31:50 +00:00
cmd cmd/{asm,compile,internal/obj}: add "maymorestack" support 2021-11-05 00:52:06 +00:00
compress compress/lzw: output a Clear code first, per GIF spec 2021-10-12 11:00:47 +00:00
constraints constraints: remove Slice/Map/Chan 2021-10-27 22:17:35 +00:00
container container/list: remove unnecessary code 2021-10-26 00:30:24 +00:00
context
crypto crypto/ecdsa: draw a fixed amount of entropy while signing 2021-11-05 04:20:33 +00:00
database/sql database/sql: fix tx.Prepare documentation 2021-11-03 23:48:28 +00:00
debug debug/gosym: bulk allocate Syms 2021-11-02 18:24:18 +00:00
embed embed/internal/embedtest: use parenthesized vars for one test 2021-10-26 23:12:17 +00:00
encoding encoding: simplify some code 2021-11-02 03:53:23 +00:00
errors errors: improve wording in As doc comment 2021-11-02 20:59:34 +00:00
expvar
flag all: use reflect.{Pointer,PointerTo} 2021-10-26 14:24:17 +00:00
fmt all: use reflect.{Pointer,PointerTo} 2021-10-26 14:24:17 +00:00
go cmd/doc, go/doc: add basic support for generic code 2021-11-04 14:54:46 +00:00
hash all: go fix -fix=buildtag std cmd (except for bootstrap deps, vendor) 2021-10-28 18:17:57 +00:00
html all: go fix -fix=buildtag std cmd (except for bootstrap deps, vendor) 2021-10-28 18:17:57 +00:00
image image/draw: rename and reorder some benchmarks 2021-10-31 08:29:02 +00:00
index/suffixarray all: go fix -fix=buildtag std cmd (except for bootstrap deps, vendor) 2021-10-28 18:17:57 +00:00
internal internal/poll: re-use RawSockaddrAny buffers across requests on windows 2021-11-04 21:52:51 +00:00
io io: remove UTF8 specified document for RuneReader 2021-10-29 02:16:47 +00:00
log all: go fix -fix=buildtag std cmd (except for bootstrap deps, vendor) 2021-10-28 18:17:57 +00:00
math all: go fix -fix=buildtag std cmd (except for bootstrap deps, vendor) 2021-10-28 18:17:57 +00:00
mime all: go fix -fix=buildtag std cmd (except for bootstrap deps, vendor) 2021-10-28 18:17:57 +00:00
net net: add UDP allocs test 2021-11-04 21:53:05 +00:00
os all: go fix -fix=buildtag std cmd (except for bootstrap deps, vendor) 2021-10-28 18:17:57 +00:00
path all: go fix -fix=buildtag std cmd (except for bootstrap deps, vendor) 2021-10-28 18:17:57 +00:00
plugin all: go fix -fix=buildtag std cmd (except for bootstrap deps, vendor) 2021-10-28 18:17:57 +00:00
reflect reflect: avoid stack copies of hiter 2021-10-31 18:39:05 +00:00
regexp all: go fix -fix=buildtag std cmd (except for bootstrap deps, vendor) 2021-10-28 18:17:57 +00:00
runtime runtime: add a maymorestack hook that moves the stack 2021-11-05 00:52:09 +00:00
sort
strconv all: use bytes.Cut, strings.Cut 2021-10-06 15:53:04 +00:00
strings net/netip: add new IP address package 2021-11-02 01:28:01 +00:00
sync sync/atomic: disable GC during TestHammerStoreLoad 2021-11-04 23:35:26 +00:00
syscall net: pass around pointers to SockaddrInetN 2021-11-04 21:52:36 +00:00
testdata
testing testing: reduce memory used by subtest names 2021-11-01 02:47:30 +00:00
text text/template: use reflect.Value.FieldByIndexErr 2021-10-29 02:12:05 +00:00
time all: go fix -fix=buildtag std cmd (except for bootstrap deps, vendor) 2021-10-28 18:17:57 +00:00
unicode unicode: use IsSpace not IsUpper in IsSpace example test 2021-10-08 00:18:29 +00:00
unsafe
vendor cmd/pprof: update vendored github.com/google/pprof 2021-11-04 16:59:45 +00:00
Make.dist
README.vendor
all.bash
all.bat
all.rc
bootstrap.bash
buildall.bash
clean.bash
clean.bat
clean.rc
cmp.bash
go.mod cmd/pprof: update vendored github.com/google/pprof 2021-11-04 16:59:45 +00:00
go.sum cmd/pprof: update vendored github.com/google/pprof 2021-11-04 16:59:45 +00:00
make.bash
make.bat
make.rc
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'.