aboutsummaryrefslogtreecommitdiffstats
path: root/lib/compiler/test/fun_SUITE.erl
diff options
context:
space:
mode:
authorJohn Högberg <[email protected]>2018-10-05 14:33:01 +0200
committerJohn Högberg <[email protected]>2018-10-05 15:43:14 +0200
commitd6509e377db65f2afd7394db2a5154e420dfd4dc (patch)
treeb0f90aaafa4ae081412ad0412119456d172e9bcb /lib/compiler/test/fun_SUITE.erl
parent1b4ad9a2d65a094285a40ae8507bc5b46a59b2e9 (diff)
downloadotp-d6509e377db65f2afd7394db2a5154e420dfd4dc.tar.gz
otp-d6509e377db65f2afd7394db2a5154e420dfd4dc.tar.bz2
otp-d6509e377db65f2afd7394db2a5154e420dfd4dc.zip
beam_ssa_pre_codegen: Literal funs need stack frames too
Fixes a crash during code generation of the following code: call_atom() -> fun({send = Send}) -> Send() end.
Diffstat (limited to 'lib/compiler/test/fun_SUITE.erl')
-rw-r--r--lib/compiler/test/fun_SUITE.erl7
1 files changed, 7 insertions, 0 deletions
diff --git a/lib/compiler/test/fun_SUITE.erl b/lib/compiler/test/fun_SUITE.erl
index e00885fcd6..1df0a05275 100644
--- a/lib/compiler/test/fun_SUITE.erl
+++ b/lib/compiler/test/fun_SUITE.erl
@@ -249,6 +249,13 @@ badfun(_Config) ->
expect_badfun(X, catch X(put(?FUNCTION_NAME, of_course))),
of_course = erase(?FUNCTION_NAME),
+ %% A literal as a Fun used to crash the code generator. This only happened
+ %% when type optimization had reduced `Fun` to a literal, hence the match.
+ Literal = fun(literal = Fun) ->
+ Fun()
+ end,
+ expect_badfun(literal, catch Literal(literal)),
+
ok.
expect_badfun(Term, Exit) ->