]> Cypherpunks repositories - gostls13.git/commitdiff
[release-branch.go1.16] syscall: avoid writing to p when Pipe(p) fails
authorRuss Cox <rsc@golang.org>
Wed, 8 Dec 2021 23:06:41 +0000 (18:06 -0500)
committerFilippo Valsorda <filippo@golang.org>
Thu, 9 Dec 2021 12:28:59 +0000 (12:28 +0000)
Generally speaking Go functions make no guarantees
about what has happened to result parameters on error,
and Pipe is no exception: callers should avoid looking at
p if Pipe returns an error.

However, we had a bug in which ForkExec was using the
content of p after a failed Pipe, and others may too.
As a robustness fix, make Pipe avoid writing to p on failure.

Updates #50057

Change-Id: Ie8955025dbd20702fabadc9bbe1d1a5ac0f36305
Reviewed-on: https://team-review.git.corp.google.com/c/golang/go-private/+/1291271
Reviewed-by: Ian Lance Taylor <iant@google.com>
Reviewed-on: https://go-review.googlesource.com/c/go/+/370515
Trust: Filippo Valsorda <filippo@golang.org>
Run-TryBot: Filippo Valsorda <filippo@golang.org>
TryBot-Result: Gopher Robot <gobot@golang.org>
Reviewed-by: Alex Rakoczy <alex@golang.org>
17 files changed:
src/syscall/syscall_aix.go
src/syscall/syscall_darwin.go
src/syscall/syscall_dragonfly.go
src/syscall/syscall_freebsd.go
src/syscall/syscall_linux_386.go
src/syscall/syscall_linux_amd64.go
src/syscall/syscall_linux_arm.go
src/syscall/syscall_linux_arm64.go
src/syscall/syscall_linux_mips64x.go
src/syscall/syscall_linux_mipsx.go
src/syscall/syscall_linux_ppc64x.go
src/syscall/syscall_linux_riscv64.go
src/syscall/syscall_linux_s390x.go
src/syscall/syscall_netbsd.go
src/syscall/syscall_openbsd.go
src/syscall/syscall_plan9.go
src/syscall/syscall_solaris.go

index 9c6afba442e2f2adf2227fb05845af8aeee9ddc4..db289fd39c12ac6c1ec3ba6fa4ee67ad973a0e23 100644 (file)
@@ -64,8 +64,10 @@ func Pipe(p []int) (err error) {
        }
        var pp [2]_C_int
        err = pipe(&pp)
-       p[0] = int(pp[0])
-       p[1] = int(pp[1])
+       if err == nil {
+               p[0] = int(pp[0])
+               p[1] = int(pp[1])
+       }
        return
 }
 
index afdadbf89468d728cc94613ab3c7f0d6c6afb529..2d4aa5867e005c47de36647c3d1f7abaef9b557e 100644 (file)
@@ -93,8 +93,10 @@ func Pipe(p []int) (err error) {
        }
        var q [2]int32
        err = pipe(&q)
-       p[0] = int(q[0])
-       p[1] = int(q[1])
+       if err == nil {
+               p[0] = int(q[0])
+               p[1] = int(q[1])
+       }
        return
 }
 
index 0988fe46088a8818b70ac3b82ce7ca987d5248ed..b3be59d02d903fc6c1509d96cd126fbe4ccf0be1 100644 (file)
@@ -96,8 +96,11 @@ func Pipe(p []int) (err error) {
        if len(p) != 2 {
                return EINVAL
        }
-       p[0], p[1], err = pipe()
-       return
+       r, w, err := pipe()
+       if err == nil {
+               p[0], p[1] = r, w
+       }
+       return err
 }
 
 //sys  extpread(fd int, p []byte, flags int, offset int64) (n int, err error)
index 7c7b89aab9030aa91683b372267d96bb49166217..ad904d69817120639867dc3ca7fb8914d0d38efd 100644 (file)
@@ -105,8 +105,10 @@ func Pipe2(p []int, flags int) error {
        }
        var pp [2]_C_int
        err := pipe2(&pp, flags)
-       p[0] = int(pp[0])
-       p[1] = int(pp[1])
+       if err == nil {
+               p[0] = int(pp[0])
+               p[1] = int(pp[1])
+       }
        return err
 }
 
index ed5264740346bad129dc8feaeb7fcc15fb2650d8..f08007b278613622130ba447de59195d19ae16b0 100644 (file)
@@ -30,8 +30,10 @@ func Pipe(p []int) (err error) {
        }
        var pp [2]_C_int
        err = pipe(&pp)
-       p[0] = int(pp[0])
-       p[1] = int(pp[1])
+       if err == nil {
+               p[0] = int(pp[0])
+               p[1] = int(pp[1])
+       }
        return
 }
 
@@ -43,8 +45,10 @@ func Pipe2(p []int, flags int) (err error) {
        }
        var pp [2]_C_int
        err = pipe2(&pp, flags)
-       p[0] = int(pp[0])
-       p[1] = int(pp[1])
+       if err == nil {
+               p[0] = int(pp[0])
+               p[1] = int(pp[1])
+       }
        return
 }
 
index 5df3f796d1677785114bad853ae8479e8fee83b6..896117adc847534782d9870b09c02fd2abc40cbb 100644 (file)
@@ -118,8 +118,10 @@ func Pipe(p []int) (err error) {
        }
        var pp [2]_C_int
        err = pipe(&pp)
-       p[0] = int(pp[0])
-       p[1] = int(pp[1])
+       if err == nil {
+               p[0] = int(pp[0])
+               p[1] = int(pp[1])
+       }
        return
 }
 
@@ -131,8 +133,10 @@ func Pipe2(p []int, flags int) (err error) {
        }
        var pp [2]_C_int
        err = pipe2(&pp, flags)
-       p[0] = int(pp[0])
-       p[1] = int(pp[1])
+       if err == nil {
+               p[0] = int(pp[0])
+               p[1] = int(pp[1])
+       }
        return
 }
 
index 4a3729f8981b520df330b24674abc1e61b8b1948..8f21f17d6f578fe4f59f6483b18c8f55c0126099 100644 (file)
@@ -34,8 +34,10 @@ func Pipe(p []int) (err error) {
        if err == ENOSYS {
                err = pipe(&pp)
        }
-       p[0] = int(pp[0])
-       p[1] = int(pp[1])
+       if err == nil {
+               p[0] = int(pp[0])
+               p[1] = int(pp[1])
+       }
        return
 }
 
@@ -47,8 +49,10 @@ func Pipe2(p []int, flags int) (err error) {
        }
        var pp [2]_C_int
        err = pipe2(&pp, flags)
-       p[0] = int(pp[0])
-       p[1] = int(pp[1])
+       if err == nil {
+               p[0] = int(pp[0])
+               p[1] = int(pp[1])
+       }
        return
 }
 
index f575c84c930c2d0a884893289a285a939a0b4b07..bfa7be96aa30914529502b823609ebea575b38c1 100644 (file)
@@ -152,8 +152,10 @@ func Pipe(p []int) (err error) {
        }
        var pp [2]_C_int
        err = pipe2(&pp, 0)
-       p[0] = int(pp[0])
-       p[1] = int(pp[1])
+       if err == nil {
+               p[0] = int(pp[0])
+               p[1] = int(pp[1])
+       }
        return
 }
 
@@ -165,8 +167,10 @@ func Pipe2(p []int, flags int) (err error) {
        }
        var pp [2]_C_int
        err = pipe2(&pp, flags)
-       p[0] = int(pp[0])
-       p[1] = int(pp[1])
+       if err == nil {
+               p[0] = int(pp[0])
+               p[1] = int(pp[1])
+       }
        return
 }
 
index ab25b7be6f1313579973f7d6493239cd1dbd52b0..bb69b1dffb787f739c87b30af73d967eb7554cd2 100644 (file)
@@ -108,8 +108,10 @@ func Pipe(p []int) (err error) {
        }
        var pp [2]_C_int
        err = pipe2(&pp, 0)
-       p[0] = int(pp[0])
-       p[1] = int(pp[1])
+       if err == nil {
+               p[0] = int(pp[0])
+               p[1] = int(pp[1])
+       }
        return
 }
 
@@ -121,8 +123,10 @@ func Pipe2(p []int, flags int) (err error) {
        }
        var pp [2]_C_int
        err = pipe2(&pp, flags)
-       p[0] = int(pp[0])
-       p[1] = int(pp[1])
+       if err == nil {
+               p[0] = int(pp[0])
+               p[1] = int(pp[1])
+       }
        return
 }
 
index 377946fc92dd0b7103839228c4d5661fc47d6371..99a3fad40121c0852900bbad6edec6f3b13865e9 100644 (file)
@@ -119,8 +119,10 @@ func Pipe2(p []int, flags int) (err error) {
        }
        var pp [2]_C_int
        err = pipe2(&pp, flags)
-       p[0] = int(pp[0])
-       p[1] = int(pp[1])
+       if err == nil {
+               p[0] = int(pp[0])
+               p[1] = int(pp[1])
+       }
        return
 }
 
@@ -130,8 +132,11 @@ func Pipe(p []int) (err error) {
        if len(p) != 2 {
                return EINVAL
        }
-       p[0], p[1], err = pipe()
-       return
+       r, w, err := pipe()
+       if err == nil {
+               p[0], p[1] = r, w
+       }
+       return err
 }
 
 //sys  mmap2(addr uintptr, length uintptr, prot int, flags int, fd int, pageOffset uintptr) (xaddr uintptr, err error)
index 45bf667407fef8782045a2a1fc0087c69a47fb3e..639d5c64abc11dbf5f4969c55cdd1574529e2aa7 100644 (file)
@@ -87,8 +87,10 @@ func Pipe(p []int) (err error) {
        }
        var pp [2]_C_int
        err = pipe2(&pp, 0)
-       p[0] = int(pp[0])
-       p[1] = int(pp[1])
+       if err == nil {
+               p[0] = int(pp[0])
+               p[1] = int(pp[1])
+       }
        return
 }
 
@@ -100,8 +102,10 @@ func Pipe2(p []int, flags int) (err error) {
        }
        var pp [2]_C_int
        err = pipe2(&pp, flags)
-       p[0] = int(pp[0])
-       p[1] = int(pp[1])
+       if err == nil {
+               p[0] = int(pp[0])
+               p[1] = int(pp[1])
+       }
        return
 }
 
index 2a0fe64d258617a8dc147d17d55cc8d205e0905b..dd48f7c8db74f63b2c558922d8fd685c44c54982 100644 (file)
@@ -155,8 +155,10 @@ func Pipe(p []int) (err error) {
        }
        var pp [2]_C_int
        err = pipe2(&pp, 0)
-       p[0] = int(pp[0])
-       p[1] = int(pp[1])
+       if err == nil {
+               p[0] = int(pp[0])
+               p[1] = int(pp[1])
+       }
        return
 }
 
@@ -168,8 +170,10 @@ func Pipe2(p []int, flags int) (err error) {
        }
        var pp [2]_C_int
        err = pipe2(&pp, flags)
-       p[0] = int(pp[0])
-       p[1] = int(pp[1])
+       if err == nil {
+               p[0] = int(pp[0])
+               p[1] = int(pp[1])
+       }
        return
 }
 
index 0f6f6277bbfda2b02aab58268b77ce9b796c2097..08e66136b8188c65e20c31234327ba0203af2655 100644 (file)
@@ -80,8 +80,10 @@ func Pipe(p []int) (err error) {
        }
        var pp [2]_C_int
        err = pipe2(&pp, 0)
-       p[0] = int(pp[0])
-       p[1] = int(pp[1])
+       if err == nil {
+               p[0] = int(pp[0])
+               p[1] = int(pp[1])
+       }
        return
 }
 
@@ -93,8 +95,10 @@ func Pipe2(p []int, flags int) (err error) {
        }
        var pp [2]_C_int
        err = pipe2(&pp, flags)
-       p[0] = int(pp[0])
-       p[1] = int(pp[1])
+       if err == nil {
+               p[0] = int(pp[0])
+               p[1] = int(pp[1])
+       }
        return
 }
 
index fc13b706b5da3c621f87177263e62984d433ea53..0754bad5ac1fac02d1ed9c4101322cdcd136ac82 100644 (file)
@@ -112,8 +112,10 @@ func Pipe2(p []int, flags int) error {
        }
        var pp [2]_C_int
        err := pipe2(&pp, flags)
-       p[0] = int(pp[0])
-       p[1] = int(pp[1])
+       if err == nil {
+               p[0] = int(pp[0])
+               p[1] = int(pp[1])
+       }
        return err
 }
 
index 5a5ba5a51b07b7d7f908b74a2831c2ab57c338c7..18eafe3521d590ce076a4ccc095b43506e40e665 100644 (file)
@@ -72,8 +72,10 @@ func Pipe2(p []int, flags int) error {
        }
        var pp [2]_C_int
        err := pipe2(&pp, flags)
-       p[0] = int(pp[0])
-       p[1] = int(pp[1])
+       if err == nil {
+               p[0] = int(pp[0])
+               p[1] = int(pp[1])
+       }
        return err
 }
 
index d16cad45d851da0de4cb30a954f98f3c3c349dbe..6a8ab97dc6cc9238d5d8af1073005156c94343d0 100644 (file)
@@ -198,8 +198,10 @@ func Pipe(p []int) (err error) {
        }
        var pp [2]int32
        err = pipe(&pp)
-       p[0] = int(pp[0])
-       p[1] = int(pp[1])
+       if err == nil {
+               p[0] = int(pp[0])
+               p[1] = int(pp[1])
+       }
        return
 }
 
index daa4b88a71d6fcb6d9d03c3048006d52fd9c135f..7640aac25b3aaaddcb4094794f5c9a26e453bed8 100644 (file)
@@ -55,7 +55,9 @@ func Pipe(p []int) (err error) {
        if e1 != 0 {
                err = Errno(e1)
        }
-       p[0], p[1] = int(r0), int(w0)
+       if err == nil {
+               p[0], p[1] = int(r0), int(w0)
+       }
        return
 }