File: compileCommon.ml

package info (click to toggle)
herdtools7 7.58-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 19,732 kB
  • sloc: ml: 128,583; ansic: 3,827; makefile: 670; python: 407; sh: 212; awk: 14
file content (98 lines) | stat: -rw-r--r-- 3,115 bytes parent folder | download
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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
(****************************************************************************)
(*                           the diy toolsuite                              *)
(*                                                                          *)
(* Jade Alglave, University College London, UK.                             *)
(* Luc Maranget, INRIA Paris-Rocquencourt, France.                          *)
(*                                                                          *)
(* Copyright 2010-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.            *)
(****************************************************************************)

module type Config = sig
  val verbose : int
  val show : ShowGen.t option
  val same_loc : bool
  val unrollatomic : int option
  val allow_back : bool
  val typ : TypBase.t
  val hexa : bool
  val moreedges : bool
  val variant : Variant_gen.t -> bool
end

module type S = sig
  module A : Arch_gen.S

  module E : Edge.S
  with type fence = A.fence
  and type dp = A.dp
  and module SIMD = A.SIMD
  and type atom = A.atom
  and type rmw = A.rmw

  type check = E.edge list list -> bool

  module R : Relax.S
  with type fence = A.fence
  and type dp = A.dp
  and type edge = E.edge

  module C : Cycle.S
   with type fence = A.fence
   and type edge=E.edge
   and module SIMD = A.SIMD
   and type atom = A.atom
   and module PteVal = A.PteVal
end

module Make(C:Config) (A:Arch_gen.S) = struct
  module A = A

  module E =
    Edge.Make
      (struct
        let variant = C.variant
        let naturalsize = TypBase.get_size C.typ
      end)
      (A)

  type check = E.edge list list -> bool

  let () = match C.show with
  | Some s -> begin
      try E.show s ; exit 0
      with e -> Printexc.print_backtrace stderr ;
        flush stderr ; raise e
  end
  | None -> ()

  module R = Relax.Make(A) (E)
  module Conf = struct
    include C
    let naturalsize = TypBase.get_size C.typ
  end
  module C = Cycle.Make(Conf)(E)
(* Big constant *)
  let kbig = 128
(* Postlude *)

  let mk_postlude emit_store_reg st p init cs =
    if A.get_noks st > 0  then
      let ok,st = A.ok_reg st in
(* Add explict `int` type for `ok<n>` variables *)
      let ok_loc = Code.as_data (Code.myok_proc p) in
      let st = A.add_type (A.Loc ok_loc) TypBase.Int st in
      let init,cs_store,st = emit_store_reg st p init ok_loc ok in
      let csok = A.Label (Label.last p,A.Nop)::cs_store in
(* Add explict initialvalue of zero for `ok<n>` variables *)
      (A.Loc ok_loc,Some (A.S "0"))::init,cs@csok,st
    else
      init,cs,st

end