diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-28 13:14:23 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-28 13:14:23 +0000 |
commit | 73df946d56c74384511a194dd01dbe099584fd1a (patch) | |
tree | fd0bcea490dd81327ddfbb31e215439672c9a068 /test/fixedbugs/issue24799.go | |
parent | Initial commit. (diff) | |
download | golang-1.16-73df946d56c74384511a194dd01dbe099584fd1a.tar.xz golang-1.16-73df946d56c74384511a194dd01dbe099584fd1a.zip |
Adding upstream version 1.16.10.upstream/1.16.10upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r-- | test/fixedbugs/issue24799.go | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/test/fixedbugs/issue24799.go b/test/fixedbugs/issue24799.go new file mode 100644 index 0000000..c805c86 --- /dev/null +++ b/test/fixedbugs/issue24799.go @@ -0,0 +1,58 @@ +// run + +// Copyright 2018 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. + +// Loads of 8 byte go.strings cannot use DS relocation +// in case the alignment is not a multiple of 4. + +package main + +import ( + "fmt" +) + +type Level string + +// The following are all go.strings. A link time error can +// occur if an 8 byte load is used to load a go.string that is +// not aligned to 4 bytes due to the type of relocation that +// is generated for the instruction. A fix was made to avoid +// generating an instruction with DS relocation for go.strings +// since their alignment is not known until link time. + +// This problem only affects go.string since other types have +// correct alignment. + +const ( + LevelBad Level = "badvals" + LevelNone Level = "No" + LevelMetadata Level = "Metadata" + LevelRequest Level = "Request" + LevelRequestResponse Level = "RequestResponse" +) + +func ordLevel(l Level) int { + switch l { + case LevelMetadata: + return 1 + case LevelRequest: + return 2 + case LevelRequestResponse: + return 3 + default: + return 0 + } +} + +//go:noinline +func test(l Level) { + if ordLevel(l) < ordLevel(LevelMetadata) { + fmt.Printf("OK\n") + } +} + +func main() { + test(LevelMetadata) +} |