src/Pure/Concurrent/thread_attributes.ML
author wenzelm
Sat, 20 Aug 2022 17:59:13 +0200
changeset 75929 811092261546
parent 64564 fc66a76d6b95
child 78713 a44ac17ae227
permissions -rw-r--r--
proper node_dir within presentation_dir, not source file directory;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
62923
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
     1
(*  Title:      Pure/Concurrent/thread_attributes.ML
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
     3
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
     4
Thread attributes for interrupt handling.
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
     5
*)
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
     6
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
     7
signature THREAD_ATTRIBUTES =
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
     8
sig
64557
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
     9
  type attributes
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    10
  val get_attributes: unit -> attributes
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    11
  val set_attributes: attributes -> unit
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    12
  val convert_attributes: attributes -> Thread.Thread.threadAttribute list
62923
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
    13
  val no_interrupts: attributes
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
    14
  val test_interrupts: attributes
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
    15
  val public_interrupts: attributes
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
    16
  val private_interrupts: attributes
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
    17
  val sync_interrupts: attributes -> attributes
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
    18
  val safe_interrupts: attributes -> attributes
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
    19
  val with_attributes: attributes -> (attributes -> 'a) -> 'a
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
    20
  val uninterruptible: ((('c -> 'd) -> 'c -> 'd) -> 'a -> 'b) -> 'a -> 'b
62924
ce47945ce4fb tuned signature -- closer to Exn.Interrupt.expose in Scala;
wenzelm
parents: 62923
diff changeset
    21
  val expose_interrupt: unit -> unit  (*exception Interrupt*)
62923
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
    22
end;
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
    23
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
    24
structure Thread_Attributes: THREAD_ATTRIBUTES =
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
    25
struct
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
    26
64557
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    27
abstype attributes = Attributes of Word.word
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    28
with
62923
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
    29
64557
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    30
(* thread attributes *)
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    31
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    32
val thread_attributes = 0w7;
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    33
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    34
val broadcast = 0w1;
62923
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
    35
64557
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    36
val interrupt_state = 0w6;
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    37
val interrupt_defer = 0w0;
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    38
val interrupt_synch = 0w2;
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    39
val interrupt_asynch = 0w4;
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    40
val interrupt_asynch_once = 0w6;
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    41
62923
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
    42
64557
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    43
(* access thread flags *)
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    44
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    45
val thread_flags = 0w1;
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    46
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    47
fun load_word () : word =
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    48
  RunCall.loadWord (RunCall.unsafeCast (Thread.Thread.self ()), thread_flags);
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    49
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    50
fun get_attributes () = Attributes (Word.andb (load_word (), thread_attributes));
62923
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
    51
64557
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    52
fun set_attributes (Attributes w) =
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    53
  let
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    54
    val w' = Word.orb (Word.andb (load_word (), Word.notb thread_attributes), w);
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    55
    val _ = RunCall.storeWord (RunCall.unsafeCast (Thread.Thread.self ()), thread_flags, w');
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    56
  in
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    57
    if Word.andb (w', interrupt_asynch) = interrupt_asynch
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    58
    then Thread.Thread.testInterrupt () else ()
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    59
  end;
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    60
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    61
fun convert_attributes (Attributes w) =
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    62
  [Thread.Thread.EnableBroadcastInterrupt (Word.andb (w, broadcast) = broadcast),
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    63
   Thread.Thread.InterruptState
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    64
      let val w' = Word.andb (w, interrupt_state) in
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    65
        if w' = interrupt_defer then Thread.Thread.InterruptDefer
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    66
        else if w' = interrupt_synch then Thread.Thread.InterruptSynch
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    67
        else if w' = interrupt_asynch then Thread.Thread.InterruptAsynch
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    68
        else Thread.Thread.InterruptAsynchOnce
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    69
      end];
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    70
62923
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
    71
64557
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    72
(* common configurations *)
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    73
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    74
val no_interrupts = Attributes interrupt_defer;
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    75
val test_interrupts = Attributes interrupt_synch;
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    76
val public_interrupts = Attributes (Word.orb (broadcast, interrupt_asynch_once));
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    77
val private_interrupts = Attributes interrupt_asynch_once;
62923
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
    78
64557
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    79
fun sync_interrupts (Attributes w) =
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    80
  let
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    81
    val w' = Word.andb (w, interrupt_state);
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    82
    val w'' = Word.andb (w, Word.notb interrupt_state);
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    83
  in Attributes (if w' = interrupt_defer then w else Word.orb (w'', interrupt_synch)) end;
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    84
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    85
fun safe_interrupts (Attributes w) =
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    86
  let
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    87
    val w' = Word.andb (w, interrupt_state);
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    88
    val w'' = Word.andb (w, Word.notb interrupt_state);
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    89
  in Attributes (if w' = interrupt_asynch then Word.orb (w'', interrupt_asynch_once) else w) end;
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
    90
62923
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
    91
fun with_attributes new_atts e =
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
    92
  let
64564
wenzelm
parents: 64557
diff changeset
    93
    val atts1 = safe_interrupts (get_attributes ());
wenzelm
parents: 64557
diff changeset
    94
    val atts2 = safe_interrupts new_atts;
wenzelm
parents: 64557
diff changeset
    95
  in
wenzelm
parents: 64557
diff changeset
    96
    if atts1 = atts2 then e atts1
wenzelm
parents: 64557
diff changeset
    97
    else
wenzelm
parents: 64557
diff changeset
    98
      let
wenzelm
parents: 64557
diff changeset
    99
        val result = Exn.capture (fn () => (set_attributes atts2; e atts1)) ();
wenzelm
parents: 64557
diff changeset
   100
        val _ = set_attributes atts1;
wenzelm
parents: 64557
diff changeset
   101
      in Exn.release result end
wenzelm
parents: 64557
diff changeset
   102
  end;
wenzelm
parents: 64557
diff changeset
   103
wenzelm
parents: 64557
diff changeset
   104
end;
62923
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
   105
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
   106
fun uninterruptible f x =
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
   107
  with_attributes no_interrupts (fn atts =>
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
   108
    f (fn g => fn y => with_attributes atts (fn _ => g y)) x);
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
   109
62924
ce47945ce4fb tuned signature -- closer to Exn.Interrupt.expose in Scala;
wenzelm
parents: 62923
diff changeset
   110
fun expose_interrupt () =
ce47945ce4fb tuned signature -- closer to Exn.Interrupt.expose in Scala;
wenzelm
parents: 62923
diff changeset
   111
  let
64557
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
   112
    val orig_atts = safe_interrupts (get_attributes ());
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
   113
    val _ = set_attributes test_interrupts;
62924
ce47945ce4fb tuned signature -- closer to Exn.Interrupt.expose in Scala;
wenzelm
parents: 62923
diff changeset
   114
    val test = Exn.capture Thread.Thread.testInterrupt ();
64557
37074e22e8be more tight thread attributes, based in internal word arithmetic instead of symbolic datatypes: measurable performance improvement;
wenzelm
parents: 62924
diff changeset
   115
    val _ = set_attributes orig_atts;
62924
ce47945ce4fb tuned signature -- closer to Exn.Interrupt.expose in Scala;
wenzelm
parents: 62923
diff changeset
   116
  in Exn.release test end;
ce47945ce4fb tuned signature -- closer to Exn.Interrupt.expose in Scala;
wenzelm
parents: 62923
diff changeset
   117
62923
3a122e1e352a clarified bootstrap;
wenzelm
parents:
diff changeset
   118
end;