forked from herd/herdtools7
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlangUtils.ml
40 lines (34 loc) · 1.95 KB
/
langUtils.ml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
(****************************************************************************)
(* the diy toolsuite *)
(* *)
(* Jade Alglave, University College London, UK. *)
(* Luc Maranget, INRIA Paris-Rocquencourt, France. *)
(* *)
(* Copyright 2014-present Institut National de Recherche en Informatique et *)
(* en Automatique and the authors. All rights reserved. *)
(* *)
(* This software is governed by the CeCILL-B license under French law and *)
(* abiding by the rules of distribution of free software. You can use, *)
(* modify and/ or redistribute the software under the terms of the CeCILL-B *)
(* license as circulated by CEA, CNRS and INRIA at the following URL *)
(* "http://www.cecill.info". We also give a copy in LICENSE.txt. *)
(****************************************************************************)
open Printf
let start_label proc = sprintf "LSTART_litmus_P%i" proc
let start_comment com proc = sprintf "%sSTART _litmus_P%i" com proc
let end_label proc = sprintf "LEND_litmus_P%i" proc
let end_comment com proc = sprintf "%sEND _litmus_P%i" com proc
let code_fun proc = sprintf "code%i" proc
let code_fun_cpy proc = sprintf "_code%i" proc
let code_fun_type proc = code_fun proc ^ "_t"
let dump_code_def chan noinline mode proc params =
fprintf chan "typedef void (*%s)(%s);\n\n" (code_fun_type proc) params ;
fprintf chan "%sstatic void %s(%s) {\n"
(if noinline then
match mode with
| Mode.Kvm -> "noinline "
| _ -> "__attribute__((noinline)) "
else "")
(code_fun proc) params
let dump_code_call chan indent f_id args =
fprintf chan "%s%s(%s);\n" indent f_id args