]> Cypherpunks repositories - gostls13.git/commitdiff
[release-branch.go1.21] Revert "cmd/compile: don't combine loads in generated equalit...
authorCherry Mui <cherryyz@google.com>
Mon, 6 May 2024 20:18:00 +0000 (20:18 +0000)
committerCherry Mui <cherryyz@google.com>
Mon, 6 May 2024 21:03:27 +0000 (21:03 +0000)
This reverts CL 583303.

Reason for revert: release branch is currently frozen.

Change-Id: Icbdb73b5b40690a875497dd0dc57ca84c728ef6f
Reviewed-on: https://go-review.googlesource.com/c/go/+/582961
LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
Reviewed-by: Dmitri Shuralyov <dmitshur@google.com>
src/cmd/compile/internal/compare/compare.go
test/fixedbugs/issue67160.go [deleted file]

index e848e1c858492411374218d0d7f9388f2a1a8436..1674065556401f257a87142d95cb2e559b64c212 100644 (file)
@@ -148,7 +148,7 @@ func calculateCostForType(t *types.Type) int64 {
                return EqStructCost(t)
        case types.TSLICE:
                // Slices are not comparable.
-               base.Fatalf("calculateCostForType: unexpected slice type")
+               base.Fatalf("eqStructFieldCost: unexpected slice type")
        case types.TARRAY:
                elemCost := calculateCostForType(t.Elem())
                cost = t.NumElem() * elemCost
@@ -374,11 +374,6 @@ func eqmem(p ir.Node, q ir.Node, field *types.Sym, size int64) ir.Node {
 }
 
 func eqmemfunc(size int64, t *types.Type) (fn *ir.Name, needsize bool) {
-       if !base.Ctxt.Arch.CanMergeLoads && t.Alignment() < int64(base.Ctxt.Arch.Alignment) && t.Alignment() < t.Size() {
-               // We can't use larger comparisons if the value might not be aligned
-               // enough for the larger comparison. See issues 46283 and 67160.
-               size = 0
-       }
        switch size {
        default:
                fn = typecheck.LookupRuntime("memequal")
diff --git a/test/fixedbugs/issue67160.go b/test/fixedbugs/issue67160.go
deleted file mode 100644 (file)
index be45a61..0000000
+++ /dev/null
@@ -1,32 +0,0 @@
-// run
-
-// Copyright 2024 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// Test to make sure that we don't try using larger loads for
-// generated equality functions on architectures that can't do
-// unaligned loads.
-
-package main
-
-// T has a big field that wants to be compared with larger loads/stores.
-// T is "special" because of the unnamed field, so it needs a generated equality function.
-// T is an odd number of bytes in size and has alignment 1.
-type T struct {
-       src [8]byte
-       _   byte
-}
-
-// U contains 8 copies of T, each at a different %8 alignment.
-type U [8]T
-
-//go:noinline
-func f(x, y *U) bool {
-       return *x == *y
-}
-
-func main() {
-       var a U
-       _ = f(&a, &a)
-}