src/HOL/MicroJava/JVM/JVMState.thy
author kleing
Thu, 21 Mar 2002 12:58:31 +0100
changeset 13063 b1789117a1c6
parent 13052 3bf41c474a88
child 13674 f4c64597fb02
permissions -rw-r--r--
new_Addr defined in terms of J/State.new_Addr (for compiler)
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
     1
(*  Title:      HOL/MicroJava/JVM/JVMState.thy
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
     2
    ID:         $Id$
12519
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
     3
    Author:     Cornelia Pusch, Gerwin Klein
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
     4
    Copyright   1999 Technische Universitaet Muenchen
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
     5
*)
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
     6
12911
704713ca07ea new document
kleing
parents: 12519
diff changeset
     7
header {* 
704713ca07ea new document
kleing
parents: 12519
diff changeset
     8
  \chapter{Java Virtual Machine}\label{cha:jvm}
704713ca07ea new document
kleing
parents: 12519
diff changeset
     9
  \isaheader{State of the JVM} 
704713ca07ea new document
kleing
parents: 12519
diff changeset
    10
*}
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    11
10922
f1209aff9517 Store.thy is obsolete (newref isn't used any more)
kleing
parents: 10057
diff changeset
    12
theory JVMState = Conform:
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    13
12519
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    14
section {* Frame Stack *}
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    15
types
12519
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    16
 opstack   = "val list"
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    17
 locvars   = "val list" 
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    18
 p_count   = nat
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    19
12519
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    20
 frame = "opstack \<times>     
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    21
          locvars \<times>   
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    22
          cname \<times>     
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    23
          sig \<times>     
10057
8c8d2d0d3ef8 converted to Isar, tuned
kleing
parents: 10042
diff changeset
    24
          p_count"
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    25
12519
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    26
  -- "operand stack" 
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    27
  -- "local variables (including this pointer and method parameters)"
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    28
  -- "name of class where current method is defined"
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    29
  -- "method name + parameter types"
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    30
  -- "program counter within frame"
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    31
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    32
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    33
section {* Exceptions *}
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    34
constdefs
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    35
  raise_system_xcpt :: "bool \<Rightarrow> xcpt \<Rightarrow> val option"
13063
b1789117a1c6 new_Addr defined in terms of J/State.new_Addr (for compiler)
kleing
parents: 13052
diff changeset
    36
  "raise_system_xcpt b x \<equiv> if b then Some (Addr (XcptRef x)) else None"
12519
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    37
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    38
  -- "redefines State.new\\_Addr:"
13063
b1789117a1c6 new_Addr defined in terms of J/State.new_Addr (for compiler)
kleing
parents: 13052
diff changeset
    39
  new_Addr :: "aheap \<Rightarrow> loc \<times> val option"
b1789117a1c6 new_Addr defined in terms of J/State.new_Addr (for compiler)
kleing
parents: 13052
diff changeset
    40
  "new_Addr h \<equiv> let (a, x) = State.new_Addr h 
b1789117a1c6 new_Addr defined in terms of J/State.new_Addr (for compiler)
kleing
parents: 13052
diff changeset
    41
                in  (a, raise_system_xcpt (x ~= None) OutOfMemory)"
12519
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    42
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    43
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    44
section {* Runtime State *}
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    45
types
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    46
  jvm_state = "val option \<times> aheap \<times> frame list"  -- "exception flag, heap, frames"
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    47
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    48
13052
3bf41c474a88 canonical start state
kleing
parents: 12911
diff changeset
    49
text {* a new, blank object with default values in all fields: *}
3bf41c474a88 canonical start state
kleing
parents: 12911
diff changeset
    50
constdefs
3bf41c474a88 canonical start state
kleing
parents: 12911
diff changeset
    51
  blank :: "'c prog \<Rightarrow> cname \<Rightarrow> obj"
3bf41c474a88 canonical start state
kleing
parents: 12911
diff changeset
    52
  "blank G C \<equiv> (C,init_vars (fields(G,C)))" 
3bf41c474a88 canonical start state
kleing
parents: 12911
diff changeset
    53
3bf41c474a88 canonical start state
kleing
parents: 12911
diff changeset
    54
  start_heap :: "'c prog \<Rightarrow> aheap"
3bf41c474a88 canonical start state
kleing
parents: 12911
diff changeset
    55
  "start_heap G \<equiv> empty (XcptRef NullPointer \<mapsto> blank G (Xcpt NullPointer))
13063
b1789117a1c6 new_Addr defined in terms of J/State.new_Addr (for compiler)
kleing
parents: 13052
diff changeset
    56
                        (XcptRef ClassCast \<mapsto> blank G (Xcpt ClassCast))
b1789117a1c6 new_Addr defined in terms of J/State.new_Addr (for compiler)
kleing
parents: 13052
diff changeset
    57
                        (XcptRef OutOfMemory \<mapsto> blank G (Xcpt OutOfMemory))"
13052
3bf41c474a88 canonical start state
kleing
parents: 12911
diff changeset
    58
12519
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    59
section {* Lemmas *}
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    60
12519
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    61
lemma new_AddrD:
13063
b1789117a1c6 new_Addr defined in terms of J/State.new_Addr (for compiler)
kleing
parents: 13052
diff changeset
    62
  assumes new: "new_Addr hp = (ref, xcp)" 
b1789117a1c6 new_Addr defined in terms of J/State.new_Addr (for compiler)
kleing
parents: 13052
diff changeset
    63
  shows "hp ref = None \<and> xcp = None \<or> xcp = Some (Addr (XcptRef OutOfMemory))"
b1789117a1c6 new_Addr defined in terms of J/State.new_Addr (for compiler)
kleing
parents: 13052
diff changeset
    64
proof -
b1789117a1c6 new_Addr defined in terms of J/State.new_Addr (for compiler)
kleing
parents: 13052
diff changeset
    65
  from new obtain xcpT where old: "State.new_Addr hp = (ref,xcpT)"
b1789117a1c6 new_Addr defined in terms of J/State.new_Addr (for compiler)
kleing
parents: 13052
diff changeset
    66
    by (cases "State.new_Addr hp") (simp add: new_Addr_def)
b1789117a1c6 new_Addr defined in terms of J/State.new_Addr (for compiler)
kleing
parents: 13052
diff changeset
    67
  from this [symmetric] 
b1789117a1c6 new_Addr defined in terms of J/State.new_Addr (for compiler)
kleing
parents: 13052
diff changeset
    68
  have "hp ref = None \<and> xcpT = None \<or> xcpT = Some OutOfMemory" 
b1789117a1c6 new_Addr defined in terms of J/State.new_Addr (for compiler)
kleing
parents: 13052
diff changeset
    69
    by (rule State.new_AddrD)
b1789117a1c6 new_Addr defined in terms of J/State.new_Addr (for compiler)
kleing
parents: 13052
diff changeset
    70
  with new old show ?thesis
b1789117a1c6 new_Addr defined in terms of J/State.new_Addr (for compiler)
kleing
parents: 13052
diff changeset
    71
    by (auto simp add: new_Addr_def raise_system_xcpt_def)
b1789117a1c6 new_Addr defined in terms of J/State.new_Addr (for compiler)
kleing
parents: 13052
diff changeset
    72
qed
b1789117a1c6 new_Addr defined in terms of J/State.new_Addr (for compiler)
kleing
parents: 13052
diff changeset
    73
8011
d14c4e9e9c8e *** empty log message ***
nipkow
parents:
diff changeset
    74
12519
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    75
lemma new_Addr_OutOfMemory:
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    76
  "snd (new_Addr hp) = Some xcp \<Longrightarrow> xcp = Addr (XcptRef OutOfMemory)"
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    77
proof - 
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    78
  obtain ref xp where "new_Addr hp = (ref, xp)" by (cases "new_Addr hp")
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    79
  moreover
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    80
  assume "snd (new_Addr hp) = Some xcp" 
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    81
  ultimately
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    82
  show ?thesis by (auto dest: new_AddrD)
13052
3bf41c474a88 canonical start state
kleing
parents: 12911
diff changeset
    83
qed
3bf41c474a88 canonical start state
kleing
parents: 12911
diff changeset
    84
  
12519
a955fe2879ba exception merge + cleanup
kleing
parents: 11177
diff changeset
    85
end