Skip to content

Commit

Permalink
Port value_kind changes to testsuite/tools to fix parsecmm.mly (#1060)
Browse files Browse the repository at this point in the history
failure in github CI with 32-bit tests
  • Loading branch information
gretay-js authored Jan 11, 2023
1 parent 4da84c4 commit dbec42d
Show file tree
Hide file tree
Showing 3 changed files with 17 additions and 6 deletions.
13 changes: 7 additions & 6 deletions ocaml/testsuite/tools/parsecmm.mly
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ let make_switch n selector caselist =
List.iter (fun pos -> index.(pos) <- i) posl;
actv.(i) <- (e, dbg)
done;
Cswitch(selector, index, actv, dbg)
Cswitch(selector, index, actv, dbg, value_kind ())

let access_array base numelt size =
match numelt with
Expand Down Expand Up @@ -228,7 +228,8 @@ expr:
| LPAREN binaryop expr expr RPAREN { Cop($2, [$3; $4], debuginfo ()) }
| LPAREN SEQ sequence RPAREN { $3 }
| LPAREN IF expr expr expr RPAREN
{ Cifthenelse($3, debuginfo (), $4, debuginfo (), $5, debuginfo ()) }
{ Cifthenelse($3, debuginfo (), $4, debuginfo (), $5, debuginfo (),
value_kind ()) }
| LPAREN SWITCH INTCONST expr caselist RPAREN { make_switch $3 $4 $5 }
| LPAREN WHILE expr sequence RPAREN
{
Expand All @@ -239,21 +240,21 @@ expr:
Cconst_int (x, _) when x <> 0 -> $4
| _ -> Cifthenelse($3, debuginfo (), $4, debuginfo (),
(Cexit(lbl0,[])),
debuginfo ()) in
debuginfo (), value_kind ()) in
Ccatch(Nonrecursive, [lbl0, [], Ctuple [], debuginfo ()],
Ccatch(Recursive,
[lbl1, [], Csequence(body, Cexit(lbl1, [])), debuginfo ()],
Cexit(lbl1, []))) }
Cexit(lbl1, []), value_kind ()), value_kind ()) }
| LPAREN EXIT IDENT exprlist RPAREN
{ Cexit(find_label $3, List.rev $4) }
| LPAREN CATCH sequence WITH catch_handlers RPAREN
{ let handlers = $5 in
List.iter (fun (_, l, _, _) ->
List.iter (fun (x, _) -> unbind_ident x) l) handlers;
Ccatch(Recursive, handlers, $3) }
Ccatch(Recursive, handlers, $3, value_kind ()) }
| EXIT { Cexit(0,[]) }
| LPAREN TRY sequence WITH bind_ident sequence RPAREN
{ unbind_ident $5; Ctrywith($3, $5, $6, debuginfo ()) }
{ unbind_ident $5; Ctrywith($3, $5, $6, debuginfo (), value_kind ()) }
| LPAREN VAL expr expr RPAREN
{ let open Asttypes in
Cop(Cload (Word_val, Mutable), [access_array $3 $4 Arch.size_addr],
Expand Down
8 changes: 8 additions & 0 deletions ocaml/testsuite/tools/parsecmmaux.ml
Original file line number Diff line number Diff line change
Expand Up @@ -60,3 +60,11 @@ let debuginfo ?(loc=Location.symbol_rloc ()) () =
~scopes:Scoped_location.empty_scopes loc
)
)

let value_kind () =
(* CR-someday poechsel: As the value_kind is only used when building cmm
for the first time, its precise value is not important afterward.
For now we can say that the cmm code read by parsecmm will only contain
Pgenval and it should make no difference, but this should probably be
fixed. *)
Cmm.Vval Lambda.Pgenval
2 changes: 2 additions & 0 deletions ocaml/testsuite/tools/parsecmmaux.mli
Original file line number Diff line number Diff line change
Expand Up @@ -29,3 +29,5 @@ type error =
exception Error of error

val report_error: error -> unit

val value_kind : unit -> Cmm.value_kind

0 comments on commit dbec42d

Please sign in to comment.