summaryrefslogtreecommitdiffstats
path: root/test/retjmp.dir
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-16 19:25:22 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-16 19:25:22 +0000
commitf6ad4dcef54c5ce997a4bad5a6d86de229015700 (patch)
tree7cfa4e31ace5c2bd95c72b154d15af494b2bcbef /test/retjmp.dir
parentInitial commit. (diff)
downloadgolang-1.22-f6ad4dcef54c5ce997a4bad5a6d86de229015700.tar.xz
golang-1.22-f6ad4dcef54c5ce997a4bad5a6d86de229015700.zip
Adding upstream version 1.22.1.upstream/1.22.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'test/retjmp.dir')
-rw-r--r--test/retjmp.dir/a.s16
-rw-r--r--test/retjmp.dir/main.go38
2 files changed, 54 insertions, 0 deletions
diff --git a/test/retjmp.dir/a.s b/test/retjmp.dir/a.s
new file mode 100644
index 0000000..101b342
--- /dev/null
+++ b/test/retjmp.dir/a.s
@@ -0,0 +1,16 @@
+// 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.
+
+TEXT ·f(SB), 4, $8-0
+ CALL ·f1(SB)
+ RET ·f2(SB)
+ CALL ·unreachable(SB)
+
+TEXT ·leaf(SB), 4, $0-0
+ RET ·f3(SB)
+ JMP ·unreachable(SB)
+
+TEXT ·leaf2(SB), 4, $32-0 // nonzero frame size
+ RET ·f4(SB)
+ JMP ·unreachable(SB)
diff --git a/test/retjmp.dir/main.go b/test/retjmp.dir/main.go
new file mode 100644
index 0000000..0bed5a6
--- /dev/null
+++ b/test/retjmp.dir/main.go
@@ -0,0 +1,38 @@
+// 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.
+
+package main
+
+func f()
+func leaf()
+func leaf2()
+
+var f1called, f2called, f3called, f4called bool
+
+func main() {
+ f()
+ if !f1called {
+ panic("f1 not called")
+ }
+ if !f2called {
+ panic("f2 not called")
+ }
+ leaf()
+ if !f3called {
+ panic("f3 not called")
+ }
+ leaf2()
+ if !f4called {
+ panic("f4 not called")
+ }
+}
+
+func f1() { f1called = true }
+func f2() { f2called = true }
+func f3() { f3called = true }
+func f4() { f4called = true }
+
+func unreachable() {
+ panic("unreachable function called")
+}