aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorZeke Lu <lvzecai@gmail.com>2022-09-26 14:53:54 +0000
committerGopher Robot <gobot@golang.org>2022-09-26 20:36:02 +0000
commit4da2bc2eebb480f1c2a726de05f4e085e97d3b6c (patch)
treee9255cd2bba963635cc8a4e5116ba11a3c3b739a /src
parentbd8a5b00fcf71fb711ba8996a880b5b07f7b3634 (diff)
downloadgo-4da2bc2eebb480f1c2a726de05f4e085e97d3b6c.tar.xz
internal/saferio: handle potential total size overflow in SliceCap
Before the change, "SliceCap((*int64)(nil), 1<<62)" returns 1<<62. That's because "uintptr(c)*size" overflows and gives 0 which is less than the "chunk". SliceCap should return -1 in this case. Change-Id: I4e99224c8ac0fc72032c6be86d7318d33d083cd8 GitHub-Last-Rev: ca30bcce456d20702e3699822cd4f1c963ef1cec GitHub-Pull-Request: golang/go#55870 Reviewed-on: https://go-review.googlesource.com/c/go/+/434335 Reviewed-by: Ian Lance Taylor <iant@google.com> Reviewed-by: Dmitri Shuralyov <dmitshur@google.com> Auto-Submit: Ian Lance Taylor <iant@google.com> Run-TryBot: Ian Lance Taylor <iant@google.com> TryBot-Result: Gopher Robot <gobot@golang.org> Run-TryBot: Ian Lance Taylor <iant@golang.org>
Diffstat (limited to 'src')
-rw-r--r--src/internal/saferio/io.go7
-rw-r--r--src/internal/saferio/io_test.go7
2 files changed, 12 insertions, 2 deletions
diff --git a/src/internal/saferio/io.go b/src/internal/saferio/io.go
index b10d117513..66cc044c74 100644
--- a/src/internal/saferio/io.go
+++ b/src/internal/saferio/io.go
@@ -121,8 +121,11 @@ func SliceCap(v any, c uint64) int {
if typ.Kind() != reflect.Ptr {
panic("SliceCap called with non-pointer type")
}
- size := typ.Elem().Size()
- if uintptr(c)*size > chunk {
+ size := uint64(typ.Elem().Size())
+ if size > 0 && c > (1<<64-1)/size {
+ return -1
+ }
+ if c*size > chunk {
c = uint64(chunk / size)
if c == 0 {
c = 1
diff --git a/src/internal/saferio/io_test.go b/src/internal/saferio/io_test.go
index 290181f2a0..356c9ebdd1 100644
--- a/src/internal/saferio/io_test.go
+++ b/src/internal/saferio/io_test.go
@@ -126,4 +126,11 @@ func TestSliceCap(t *testing.T) {
t.Errorf("SliceCap returned %d, expected failure", c)
}
})
+
+ t.Run("overflow", func(t *testing.T) {
+ c := SliceCap((*int64)(nil), 1<<62)
+ if c >= 0 {
+ t.Errorf("SliceCap returned %d, expected failure", c)
+ }
+ })
}