]> Cypherpunks repositories - gostls13.git/commit
[release-branch.go1.9] cmd/go: accept only limited compiler and linker flags in ...
authorRuss Cox <rsc@golang.org>
Tue, 6 Feb 2018 04:12:50 +0000 (23:12 -0500)
committerRuss Cox <rsc@google.com>
Wed, 7 Feb 2018 14:46:58 +0000 (14:46 +0000)
commit867fb18b6d5bc73266b68c9a695558a04e060a8a
tree52b3551167da1657745fce554ab4544112e3cd4e
parentc03ee1985cb6e4467246a2bdb07bb1c62e05f8e9
[release-branch.go1.9] cmd/go: accept only limited compiler and linker flags in #cgo directives

Both gcc and clang accept an option -fplugin=code.so to load
a plugin from the ELF shared object file code.so.
Obviously that plugin can then do anything it wants
during the build. This is contrary to the goal of "go get"
never running untrusted code during the build.
(What happens if you choose to run the result of
the build is your responsibility.)

Disallow this behavior by only allowing a small set of
known command-line flags in #cgo CFLAGS directives
(and #cgo LDFLAGS, etc).

The new restrictions can be adjusted by the environment
variables CGO_CFLAGS_ALLOW, CGO_CFLAGS_DISALLOW,
and so on. See the documentation.

In addition to excluding cgo-defined flags, we also have to
make sure that when we pass file names on the command
line, they don't look like flags. So we now refuse to build
packages containing suspicious file names like -x.go.

A wrinkle in all this is that GNU binutils uniformly accept
@foo on the command line to mean "if the file foo exists,
then substitute its contents for @foo in the command line".
So we must also reject @x.go, flags and flag arguments
beginning with @, and so on.

Fixes #23673, CVE-2018-6574.

Change-Id: I59e7c1355155c335a5c5ae0d2cf8fa7aa313940a
Reviewed-on: https://team-review.git.corp.google.com/212507
Reviewed-by: Ian Lance Taylor <iant@google.com>
12 files changed:
misc/cgo/errors/err1.go
src/cmd/cgo/doc.go
src/cmd/compile/internal/gc/noder.go
src/cmd/dist/build.go
src/cmd/go/alldocs.go
src/cmd/go/go_test.go
src/cmd/go/internal/envcmd/env.go
src/cmd/go/internal/help/helpdoc.go
src/cmd/go/internal/load/pkg.go
src/cmd/go/internal/work/build.go
src/cmd/go/internal/work/security.go [new file with mode: 0644]
src/cmd/go/internal/work/security_test.go [new file with mode: 0644]