Static.thy
author chunhan
Fri, 03 May 2013 08:20:21 +0100
changeset 1 7d9c0ed02b56
child 2 5a01ee1c9b4d
permissions -rwxr-xr-x
thy files
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
     1
theory Static
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
     2
imports Static_type OS_type_def Flask_type Flask
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
     3
begin
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
     4
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
     5
locale tainting_s = tainting 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
     6
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
     7
begin
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
     8
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
     9
fun init_role_of_obj :: "t_object \<Rightarrow> role_t option"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    10
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    11
  "init_role_of_obj (O_proc p) = init_role_of_proc p"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    12
| "init_role_of_obj _          = Some R_object"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    13
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    14
definition init_sectxt_of_obj :: "t_object \<Rightarrow> security_context_t option"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    15
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    16
  "init_sectxt_of_obj obj \<equiv>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    17
     (case (init_user_of_obj obj, init_role_of_obj obj, init_type_of_obj obj) of
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    18
        (Some u, Some r, Some t) \<Rightarrow> Some (u,r,t)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    19
      | _ \<Rightarrow> None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    20
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    21
(*
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    22
definition init_sectxt_of_file:: "t_file \<Rightarrow> security_context_t option"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    23
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    24
  "init_sectxt_of_file f \<equiv> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    25
     if (is_init_file f) then init_sectxt_of_obj (O_file f)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    26
     else if (is_init_dir f) then init_sectxt_of_obj (O_dir f)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    27
     else None"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    28
*)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    29
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    30
definition sec_of_root :: "security_context_t"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    31
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    32
  "sec_of_root \<equiv> (case (init_user_of_obj (O_dir []), init_type_of_obj (O_dir [])) of
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    33
     (Some u, Some t) \<Rightarrow> (u, R_object, t))"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    34
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    35
definition sroot :: "t_sfile"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    36
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    37
  "sroot \<equiv> (Init [], sec_of_root, None, {})"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    38
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    39
definition init_cf2sfile :: "t_file \<Rightarrow> t_sfile option"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    40
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    41
  "init_cf2sfile f \<equiv> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    42
     case (parent f) of 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    43
       None \<Rightarrow> Some sroot
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    44
     | Some pf \<Rightarrow> if (is_init_file f) then 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    45
 (case (init_sectxt_of_obj (O_file f), init_sectxt_of_obj (O_dir pf), get_parentfs_ctxts [] pf) of
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    46
    (Some sec, Some psec, Some aseclist) \<Rightarrow> Some (Init f, sec, Some psec, set aseclist)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    47
  | _ \<Rightarrow> None)    else 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    48
 (case (init_sectxt_of_obj (O_dir f), init_sectxt_of_obj (O_dir pf), get_parentfs_ctxts [] pf) of
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    49
    (Some sec, Some psec, Some aseclist) \<Rightarrow> Some (Init f, sec, Some psec, set aseclist)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    50
  | _ \<Rightarrow> None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    51
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    52
definition init_cfs2sfiles :: "t_file set \<Rightarrow> t_sfile set"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    53
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    54
  "init_cfs2sfiles fs \<equiv> {sf. \<exists>f \<in> fs. init_cf2sfile f = Some sf}"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    55
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    56
definition init_cfd2sfd :: "t_process \<Rightarrow> t_fd \<Rightarrow> (security_context_t \<times> t_open_flags \<times> t_sfile) option"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    57
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    58
  "init_cfd2sfd p fd = 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    59
     (case (init_file_of_proc_fd p fd, init_oflags_of_proc_fd p fd, init_sectxt_of_obj (O_fd p fd)) of
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    60
        (Some f, Some flags, Some sec) \<Rightarrow> (case (init_cf2sfile f) of 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    61
                                             Some sf \<Rightarrow> Some (sec, flags, sf)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    62
                                           | _ \<Rightarrow> None)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    63
      | _ \<Rightarrow> None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    64
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    65
definition init_cfds2sfds :: "t_process \<Rightarrow> (security_context_t \<times> t_open_flags \<times> t_sfile) set"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    66
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    67
  "init_cfds2sfds p \<equiv> { sfd. \<exists> fd sfd f. init_file_of_proc_fd p fd = Some f \<and> init_cfd2sfd p fd = Some sfd}"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    68
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    69
definition init_ch2sshm :: "t_shm \<Rightarrow> t_sshm option"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    70
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    71
  "init_ch2sshm h \<equiv> (case (init_sectxt_of_obj (O_shm h)) of
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    72
                       Some sec \<Rightarrow> Some (Init h, sec)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    73
                     | _        \<Rightarrow> None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    74
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    75
definition init_cph2spshs 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    76
  :: "t_process \<Rightarrow> (t_sshm \<times> t_shm_attach_flag) set"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    77
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    78
  "init_cph2spshs p \<equiv> {(sh, flag)| sh flag h. (p, flag) \<in> init_procs_of_shm h \<and> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    79
                                             init_ch2sshm h = Some sh}"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    80
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    81
definition init_cp2sproc :: "t_process \<Rightarrow> t_sproc option"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    82
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    83
  "init_cp2sproc p \<equiv> (case (init_sectxt_of_obj (O_proc p)) of 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    84
       Some sec \<Rightarrow> Some (Init p, sec, (init_cfds2sfds p), (init_cph2spshs p))
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    85
     | None     \<Rightarrow> None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    86
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    87
(* acient files of init-file 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    88
definition init_o2s_afs :: "t_file \<Rightarrow> security_context_t set"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    89
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    90
  "init_o2s_afs f \<equiv> {sec. \<exists> f'. f' \<preceq> f \<and> init_sectxt_of_obj (O_dir f') = Some sec}" *)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    91
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    92
definition init_cm2smsg :: "t_msgq \<Rightarrow> t_msg \<Rightarrow> t_smsg option"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    93
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    94
  "init_cm2smsg q m \<equiv> (case (init_sectxt_of_obj (O_msg q m)) of 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    95
                         Some sec \<Rightarrow> Some (Init m, sec, (O_msg q m) \<in> seeds)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    96
                       | _ \<Rightarrow> None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    97
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    98
fun init_cqm2sms :: "t_msgq \<Rightarrow> t_msg list \<Rightarrow> (t_smsg list) option"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    99
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   100
  "init_cqm2sms q []     = Some []"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   101
| "init_cqm2sms q (m#ms) = 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   102
     (case (init_cqm2sms q ms, init_cm2smsg q m) of 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   103
        (Some sms, Some sm) \<Rightarrow> Some (sm # sms)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   104
      | _        \<Rightarrow> None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   105
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   106
definition init_cq2smsgq :: "t_msgq \<Rightarrow> t_smsgq option"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   107
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   108
  "init_cq2smsgq q \<equiv> (case (init_sectxt_of_obj (O_msgq q), init_cqm2sms q (init_msgs_of_queue q)) of 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   109
       (Some sec, Some sms) \<Rightarrow> Some (Init q, sec, sms)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   110
     | _ \<Rightarrow> None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   111
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   112
definition init_same_inode_files :: "t_file \<Rightarrow> t_file set"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   113
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   114
  "init_same_inode_files f \<equiv> {f'. init_inum_of_file f = init_inum_of_file f'}"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   115
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   116
fun init_obj2sobj :: "t_object \<Rightarrow> t_sobject option"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   117
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   118
  "init_obj2sobj (O_proc p) = 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   119
     (case (init_cp2sproc p) of 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   120
       Some sp \<Rightarrow> Some (S_proc sp (O_proc p \<in> seeds))
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   121
     | _ \<Rightarrow> None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   122
| "init_obj2sobj (O_file f) = 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   123
     (if (f \<in> init_files \<and> is_init_file f) 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   124
      then Some (S_file (init_cfs2sfiles (init_same_inode_files f)) 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   125
                        (\<exists> f'. f' \<in> (init_same_inode_files f) \<and> O_file f \<in> seeds))
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   126
      else None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   127
| "init_obj2sobj (O_dir f) = 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   128
     (if (is_init_dir f) then 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   129
        (case (init_cf2sfile f) of
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   130
           Some sf \<Rightarrow> Some (S_dir sf) 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   131
         | _ \<Rightarrow> None)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   132
      else None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   133
| "init_obj2sobj (O_msgq q) = 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   134
     (case (init_cq2smsgq q) of
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   135
       Some sq \<Rightarrow> Some (S_msgq sq)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   136
     | _ \<Rightarrow> None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   137
| "init_obj2sobj (O_shm h) = 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   138
     (case (init_ch2sshm h) of 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   139
       Some sh \<Rightarrow> Some (S_shm sh)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   140
     | _       \<Rightarrow> None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   141
| "init_obj2sobj (O_msg q m) = 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   142
     (case (init_cq2smsgq q, init_cm2smsg q m) of 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   143
        (Some sq, Some sm) \<Rightarrow> Some (S_msg sq sm)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   144
      | _                  \<Rightarrow> None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   145
| "init_obj2sobj _ = None"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   146
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   147
definition  
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   148
  "init_static_state \<equiv> {sobj. \<exists> obj. init_alive obj \<and> init_obj2sobj obj = Some sobj}"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   149
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   150
fun is_init_sfile :: "t_sfile \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   151
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   152
  "is_init_sfile (Init _, sec, psec,asec) = True"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   153
| "is_init_sfile _ = False"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   154
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   155
fun is_many_sfile :: "t_sfile \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   156
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   157
  "is_many_sfile (Created, sec, psec, asec) = True"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   158
| "is_many_sfile _ = False"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   159
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   160
fun is_init_sproc :: "t_sproc \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   161
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   162
  "is_init_sproc (Init p, sec, fds, shms) = True"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   163
| "is_init_sproc _                        = False"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   164
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   165
fun is_many_sproc :: "t_sproc \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   166
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   167
  "is_many_sproc (Created, sec,fds,shms) = True"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   168
| "is_many_sproc _                       = False"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   169
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   170
fun is_many_smsg :: "t_smsg \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   171
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   172
  "is_many_smsg (Created,sec,tag) = True"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   173
| "is_many_smsg _                 = False"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   174
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   175
fun is_many_smsgq :: "t_smsgq \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   176
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   177
  "is_many_smsgq (Created,sec,sms) = (True \<and> (\<forall> sm \<in> (set sms). is_many_smsg sm))"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   178
| "is_many_smsgq _                 = False"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   179
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   180
fun is_many_sshm :: "t_sshm \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   181
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   182
  "is_many_sshm (Created, sec) = True"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   183
| "is_many_sshm _              = False"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   184
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   185
(*
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   186
fun is_init_sobj :: "t_sobject \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   187
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   188
  "is_init_sobj (S_proc (popt, sec, fds, shms) tag) = (popt \<noteq> None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   189
| "is_init_sobj (S_file sf tag) = (is_init_sfile sf)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   190
| "is_init_sobj (S_dir  sf tag) = (is_init_sfile sf)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   191
| "is_init_sobj (S_msg" *)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   192
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   193
fun is_many :: "t_sobject \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   194
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   195
  "is_many (S_proc (Many, sec, fds, shms) tag) = True"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   196
| "is_many (S_file sfs                    tag) = (\<forall> sf \<in> sfs. is_many_sfile sf)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   197
| "is_many (S_dir  sf                        ) = is_many_sfile sf"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   198
| "is_many (S_msgq sq                        ) = is_many_smsgq sq"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   199
| "is_many (S_shm  sh                        ) = is_many_sshm  sh"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   200
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   201
(*
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   202
fun update_ss_sp:: "t_static_state \<Rightarrow> t_sobject \<Rightarrow> t_sobject \<Rightarrow> t_static_state"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   203
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   204
  "update_ss_sp ss (S_proc sp tag) (S_proc sp' tag') = 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   205
     (if (is_many_sproc sp) then ss \<union> {S_proc sp' tag'} 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   206
      else (ss - {S_proc sp tag}) \<union> {S_proc sp' tag'})"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   207
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   208
fun update_ss_sd:: "t_static_state \<Rightarrow> t_sobject \<Rightarrow> t_sobject \<Rightarrow> t_static_state"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   209
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   210
  "update_ss_sd ss (S_dir sf tag) (S_dir sf' tag') = 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   211
     (if (is_many_sfile sf) then ss \<union> {S_dir sf' tag'} 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   212
      else (ss - {S_dir sf tag}) \<union> {S_dir sf' tag'})"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   213
*)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   214
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   215
definition update_ss :: "t_static_state \<Rightarrow> t_sobject \<Rightarrow> t_sobject \<Rightarrow> t_static_state"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   216
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   217
  "update_ss ss so so' \<equiv> if (is_many so) then ss \<union> {so'} else (ss - {so}) \<union> {so'}"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   218
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   219
definition add_ss :: "t_static_state \<Rightarrow> t_sobject \<Rightarrow> t_static_state"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   220
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   221
  "add_ss ss so \<equiv> ss \<union> {so}"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   222
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   223
definition del_ss :: "t_static_state \<Rightarrow> t_sobject \<Rightarrow> t_static_state"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   224
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   225
  "del_ss ss so \<equiv> if (is_many so) then ss else ss - {so}"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   226
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   227
(*
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   228
fun sparent :: "t_sfile \<Rightarrow> t_sfile option"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   229
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   230
  "sparent (Sroot si sec) = None"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   231
| "sparent (Sfile si sec spf) = Some spf"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   232
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   233
inductive is_ancesf :: "t_sfile \<Rightarrow> t_sfile \<Rightarrow> bool" 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   234
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   235
  "is_ancesf sf sf"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   236
| "sparent sf = Some spf \<Longrightarrow> is_ancesf spf sf"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   237
| "\<lbrakk>sparent sf = Some spf; is_ancesf saf spf\<rbrakk> \<Longrightarrow> is_ancesf saf sf"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   238
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   239
definition sfile_reparent :: "t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_sfile"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   240
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   241
  "sfile_reparent (Sroot)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   242
*)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   243
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   244
(*
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   245
(* sfds rename aux definitions *)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   246
definition sfds_rename_notrelated 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   247
  :: "t_sfd set \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_sfd set \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   248
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   249
  "sfds_rename_notrelated sfds from to sfds' \<equiv> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   250
     (\<forall> sec flag sf. (sec,flag,sf) \<in> sfds \<and> (\<not> from \<preceq> sf) \<longrightarrow> (sec,flag,sf) \<in> sfds')"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   251
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   252
definition sfds_rename_renamed
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   253
  :: "t_sfd set \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_sfd set \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   254
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   255
  "sfds_rename_renamed sfds sf from to sfds' \<equiv> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   256
     (\<forall> sec flag sf'. (sec,flag,sf) \<in> sfds \<and> (sf \<preceq> sf') \<longrightarrow>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   257
         (sec, flag, file_after_rename sf' from to) \<in> sfds' \<and> (sec,flag,sf) \<notin> sfds')"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   258
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   259
definition sfds_rename_remain
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   260
  :: "t_sfd set \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_sfd set \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   261
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   262
  "sfds_rename_remain sfds sf from to sfds' \<equiv> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   263
     (\<forall> sec flag sf'. (sec,flag,sf') \<in> sfds \<and> (sf \<preceq> sf') \<longrightarrow> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   264
         (sec, flag, sf') \<in> sfds' \<and> (sec,flag, file_after_rename sf' from to) \<notin> sfds')"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   265
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   266
(* for not many, choose on renamed or not *)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   267
definition sfds_rename_choices
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   268
  :: "t_sfd set \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_sfd set \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   269
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   270
  "sfds_rename_choices sfds sf from to sfds' \<equiv> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   271
     sfds_rename_remain sfds sf from to sfds' \<or> sfds_rename_renamed sfds sf from to sfds'"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   272
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   273
(* for many, merge renamed with not renamed *)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   274
definition sfds_rename_both
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   275
  :: "t_sfd set \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_sfd set \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   276
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   277
  "sfds_rename_both sfds sf from to sfds' \<equiv> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   278
     (\<forall> sec flag sf'. (sec,flag,sf') \<in> sfds \<and> (sf \<preceq> sf') \<longrightarrow> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   279
         (sec, flag, sf') \<in> sfds' \<or> (sec,flag, file_after_rename sf' from to) \<in> sfds')"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   280
  
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   281
(* added to the new sfds, are those only under the new sfile *)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   282
definition sfds_rename_added
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   283
  :: "t_sfd set \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_sfd set \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   284
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   285
  "sfds_rename_added sfds from to sfds' \<equiv> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   286
     (\<forall> sec' flag' sf' sec flag. (sec',flag',sf') \<in> sfds' \<and> (sec,flag,sf') \<notin> sfds \<longrightarrow> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   287
        (\<exists> sf. (sec,flag,sf) \<in> sfds \<and> sf' = file_after_rename from to sf))"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   288
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   289
definition sproc_sfds_renamed
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   290
  :: "t_static_state \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_static_state \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   291
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   292
  "sproc_sfds_renamed ss sf from to ss' \<equiv>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   293
     (\<forall> pi sec sfds sshms tagp. S_proc (pi,sec,sfds,sshms) tagp \<in> ss \<longrightarrow> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   294
       (\<exists> sfds'. S_proc (pi,sec,sfds',sshms) tagp \<in> ss \<and> sfds_rename_renamed sfds sf from to sfds'))"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   295
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   296
definition sproc_sfds_remain
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   297
  :: "t_static_state \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_static_state \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   298
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   299
  "sproc_sfds_remain ss sf from to ss' \<equiv>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   300
     (\<forall> pi sec sfds sshms tagp. S_proc (pi,sec,sfds,sshms) tagp \<in> ss \<longrightarrow> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   301
       (\<exists> sfds'. S_proc (pi,sec,sfds',sshms) tagp \<in> ss \<and> sfds_rename_remain sfds sf from to sfds'))"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   302
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   303
(* for not many, choose on renamed or not *)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   304
definition sproc_sfds_choices
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   305
  :: "t_static_state \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_static_state \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   306
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   307
  "sproc_sfds_choices ss sf from to ss' \<equiv>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   308
     (\<forall> pi sec sfds sshms tagp. S_proc (pi,sec,sfds,sshms) tagp \<in> ss \<longrightarrow> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   309
       (\<exists> sfds'. S_proc (pi,sec,sfds',sshms) tagp \<in> ss \<and> sfds_rename_choices sfds sf from to sfds'))"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   310
  
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   311
(* for many, merge renamed with not renamed *)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   312
definition sproc_sfds_both
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   313
  :: "t_static_state \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_static_state \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   314
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   315
  "sproc_sfds_both ss sf from to ss' \<equiv>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   316
     (\<forall> pi sec sfds sshms tagp. S_proc (pi,sec,sfds,sshms) tagp \<in> ss \<longrightarrow> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   317
       (\<exists> sfds'. S_proc (pi,sec,sfds',sshms) tagp \<in> ss \<and> sfds_rename_both sfds sf from to sfds'))"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   318
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   319
(* remove (\<forall> sp tag. S_proc sp tag \<in> ss \<longrightarrow> S_proc sp tag \<in> ss'),
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   320
 * cause sfds contains sfs informations *)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   321
definition ss_rename_notrelated 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   322
  :: "t_static_state \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_static_state \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   323
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   324
  "ss_rename_notrelated ss sf sf' ss' \<equiv> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   325
     (\<forall> sq. S_msgq sq \<in> ss \<longrightarrow> S_msgq sq \<in> ss') \<and> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   326
     (\<forall> pi sec sfds sshms tagp. S_proc (pi,sec,sfds,sshms) tagp \<in> ss \<longrightarrow> (\<exists> sfds'.  
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   327
         S_proc (pi,sec,sfds',sshms) tagp \<in> ss'\<and> sfds_rename_notrelated sfds sf sf' sfds'))  \<and>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   328
     (\<forall> sfs sf'' tag. S_file sfs tag \<in> ss \<and> sf'' \<in> sfs \<and> (\<not> sf \<preceq> sf'') \<longrightarrow> (\<exists> sfs'. 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   329
         S_file sfs tag \<in> ss' \<and> sf'' \<in> sfs')) \<and>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   330
     (\<forall> sf'' tag. S_dir sf'' tag \<in> ss \<and> (\<not> sf \<preceq> sf'') \<longrightarrow> S_dir sf'' tag \<in> ss')" 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   331
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   332
(* rename from to, from should definited renamed if not many *)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   333
definition all_descendant_sf_renamed 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   334
  :: "t_static_state \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_static_state \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   335
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   336
  "all_descendant_sf_renamed ss sf from to ss' \<equiv>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   337
     (\<forall> sfs sf' tagf. sf \<preceq> sf' \<and> S_file sfs tagf \<in> ss \<and> sf' \<in> sfs \<longrightarrow> (\<exists> sfs'. 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   338
       S_file sfs' tagf \<in> ss' \<and> file_after_rename from to sf' \<in> sfs' \<and> sf' \<notin> sfs')) \<and> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   339
     (\<forall> sf' tagf. sf \<preceq> sf' \<and> S_dir sf' tagf \<in> ss \<longrightarrow> S_dir (file_after_rename from to sf') tagf \<in> ss' \<and> S_dir sf' tagf \<notin> ss') \<and>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   340
     sproc_sfds_renamed ss sf from to ss'"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   341
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   342
(* not renamed *)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   343
definition all_descendant_sf_remain
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   344
  :: "t_static_state \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_static_state \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   345
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   346
  "all_descendant_sf_remain ss sf from to ss' \<equiv>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   347
     (\<forall> sfs sf' tag'. sf \<preceq> sf' \<and> S_file sfs tag' \<in> ss \<and> sf' \<in> sfs \<longrightarrow> (\<exists> sfs'. 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   348
       S_file sfs' tag' \<in> ss \<and> file_after_rename from to sf' \<notin> sfs' \<and> sf' \<in> sfs')) \<and> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   349
     (\<forall> sf' tag'. sf \<preceq> sf' \<and> S_dir sf' tag' \<in> ss \<longrightarrow> S_dir (file_after_rename from to sf') tag' \<notin> ss' \<and> S_dir sf' tag' \<in> ss') \<and>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   350
     sproc_sfds_remain ss sf from to ss'"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   351
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   352
definition all_descendant_sf_choices
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   353
  :: "t_static_state \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_static_state \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   354
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   355
  "all_descendant_sf_choices ss sf from to ss' \<equiv>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   356
     all_descendant_sf_renamed ss sf from to ss' \<or> all_descendant_sf_remain ss sf from to ss'"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   357
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   358
definition all_descendant_sf_both
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   359
  :: "t_static_state \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_static_state \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   360
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   361
  "all_descendant_sf_both ss sf from to ss' \<equiv>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   362
     (\<forall> sfs sf' tag'. sf \<preceq> sf' \<and> S_file sfs tag' \<in> ss \<and> sf' \<in> sfs \<longrightarrow> (\<exists> sfs'. 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   363
        S_file sfs' tag' \<in> ss \<and> file_after_rename from to sf' \<in> sfs' \<or> sf' \<in> sfs')) \<and> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   364
     (\<forall> sf' tag'. sf \<preceq> sf' \<and> S_dir sf' tag' \<in> ss \<longrightarrow> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   365
        S_dir (file_after_rename from to sf') tag' \<in> ss' \<or> S_dir sf' tag' \<in> ss') \<and>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   366
     sproc_sfds_both ss sf from to ss'"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   367
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   368
definition ss_renamed_file 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   369
  :: "t_static_state \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_static_state \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   370
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   371
  "ss_renamed_file ss sf sf' ss' \<equiv> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   372
     (if (is_many_sfile sf) 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   373
        then all_descendant_sf_choices ss sf sf sf' ss'
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   374
        else all_descendant_sf_renamed ss sf sf sf' ss')"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   375
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   376
(* added to the new sfs, are those only under the new sfile *)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   377
definition sfs_rename_added
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   378
  :: "t_sfile set \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_sfile set \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   379
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   380
  "sfs_rename_added sfs from to sfs' \<equiv> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   381
     (\<forall> sf'. sf' \<in> sfs' \<and> sf' \<notin> sfs \<longrightarrow> (\<exists> sf. sf \<in> sfs \<and> sf' = file_after_rename from to sf))"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   382
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   383
(* added to the new sfile, are those only under the new sfile *)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   384
definition ss_rename_added
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   385
  :: "t_static_state \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_static_state \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   386
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   387
  "ss_rename_added ss from to ss' \<equiv> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   388
     (\<forall> pi sec fds fds' shms tagp. S_proc (pi, sec, fds,shms) tagp \<in> ss \<and> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   389
        S_proc (pi,sec,fds',shms) tagp \<in> ss' \<longrightarrow> sfds_rename_added fds from to fds') \<and>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   390
     (\<forall> sq. S_msgq sq \<in> ss' \<longrightarrow> S_msgq sq \<in> ss) \<and>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   391
     (\<forall> sfs sfs' tagf. S_file sfs' tagf \<in> ss' \<and> S_file sfs tagf \<in> ss \<longrightarrow> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   392
        sfs_rename_added sfs from to sfs') \<and>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   393
     (\<forall> sf' tagf. S_dir sf' tagf \<in> ss' \<and> S_dir sf' tagf \<notin> ss \<longrightarrow> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   394
        (\<exists> sf. S_dir sf tagf \<in> ss \<and> sf' = file_after_rename from to sf))" 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   395
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   396
definition sfile_alive :: "t_static_state \<Rightarrow> t_sfile \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   397
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   398
  "sfile_alive ss sf \<equiv> (\<exists> sfs tagf. sf \<in> sfs \<and> S_file sfs tagf \<in> ss)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   399
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   400
definition sf_alive :: "t_static_state \<Rightarrow> t_sfile \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   401
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   402
  "sf_alive ss sf \<equiv> (\<exists> tagd. S_dir sf tagd \<in> ss) \<or> sfile_alive ss sf"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   403
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   404
(* constrains that the new static state should satisfy *)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   405
definition ss_rename:: "t_static_state \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_static_state \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   406
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   407
  "ss_rename ss sf sf' ss' \<equiv> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   408
     ss_rename_notrelated ss sf sf' ss' \<and>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   409
     ss_renamed_file ss sf sf' ss' \<and> ss_rename_added ss sf sf' ss' \<and>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   410
     (\<forall> sf''. sf_alive ss sf'' \<and> sf \<prec> sf'' \<longrightarrow> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   411
       (if (is_many_sfile sf'') 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   412
        then all_descendant_sf_choices ss sf'' sf sf' ss'
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   413
        else all_descendant_sf_both ss sf'' sf sf' ss'))"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   414
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   415
(* two sfile, the last fname should not be equal *)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   416
fun sfile_same_fname:: "t_sfile \<Rightarrow> t_sfile \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   417
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   418
  "sfile_same_fname ((Init n, sec)#spf) ((Init n', sec')#spf') = (n = n')"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   419
| "sfile_same_fname _                   _                      = False"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   420
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   421
(* no same init sfile/only sfile in the target-to spf, should be in static_state addmissble check *)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   422
definition ss_rename_no_same_fname:: "t_static_state \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   423
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   424
  "ss_rename_no_same_fname ss from spf \<equiv>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   425
    \<not> (\<exists> to. sfile_same_fname from to \<and> parent to = Some spf \<and> sf_alive ss to)" 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   426
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   427
(* is not a function, is a relation (one 2 many)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   428
definition update_ss_rename :: "t_static_state \<Rightarrow> t_sfile \<Rightarrow> t_sfile \<Rightarrow> t_static_state"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   429
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   430
  "update_ss_rename ss sf sf' \<equiv> if (is_many_sfile sf) 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   431
     then (ss \<union> {S_file (file_after_rename sf sf' sf'') tag | sf'' tag. sf \<preceq> sf'' \<and> S_file sf'' tag \<in> ss}
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   432
              \<union> {S_dir  (file_after_rename sf sf' sf'') tag | sf'' tag. sf \<preceq> sf'' \<and> S_dir sf'' tag \<in> ss})
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   433
     else (ss - {S_file sf'' tag | sf'' tag. sf \<preceq> sf'' \<and> S_file sf'' tag \<in> ss}
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   434
              - {S_dir  sf'' tag | sf'' tag. sf \<preceq> sf'' \<and> S_dir sf'' tag \<in> ss})
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   435
              \<union> {S_file (file_after_rename sf sf' sf'') tag | sf'' tag. sf \<preceq> sf'' \<and> S_file sf'' tag \<in> ss}
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   436
              \<union> {S_dir  (file_after_rename sf sf' sf'') tag | sf'' tag. sf \<preceq> sf'' \<and> S_dir sf'' tag \<in> ss}" 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   437
*)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   438
*)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   439
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   440
fun sectxt_of_sproc :: "t_sproc \<Rightarrow> security_context_t"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   441
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   442
  "sectxt_of_sproc (pi,sec,fds,shms) = sec"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   443
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   444
fun sectxt_of_sfile :: "t_sfile \<Rightarrow> security_context_t"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   445
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   446
  "sectxt_of_sfile (fi,sec,psec,asecs) = sec"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   447
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   448
fun asecs_of_sfile :: "t_sfile \<Rightarrow> security_context_t set"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   449
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   450
  "asecs_of_sfile (fi,sec,psec,asecs) = asecs"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   451
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   452
definition search_check_s :: "security_context_t \<Rightarrow> t_sfile \<Rightarrow> bool \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   453
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   454
  "search_check_s pctxt sf if_file = 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   455
    (if if_file 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   456
      then search_check_file pctxt (sectxt_of_sfile sf) \<and> search_check_allp pctxt (asecs_of_sfile sf)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   457
      else search_check_dir  pctxt (sectxt_of_sfile sf) \<and> search_check_allp pctxt (asecs_of_sfile sf))"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   458
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   459
definition sectxts_of_sfds :: "t_sfd set \<Rightarrow> security_context_t set"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   460
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   461
  "sectxts_of_sfds sfds \<equiv> {ctxt. \<exists> flag sf. (ctxt, flag, sf) \<in> sfds}"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   462
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   463
definition inherit_fds_check_s :: "security_context_t \<Rightarrow> t_sfd set \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   464
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   465
  "inherit_fds_check_s pctxt sfds \<equiv> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   466
     (\<forall> ctxt \<in> sectxts_of_sfds sfds. permission_check pctxt ctxt C_fd P_inherit)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   467
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   468
definition sectxts_of_sproc_sshms :: "t_sproc_sshm set \<Rightarrow> security_context_t set"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   469
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   470
  "sectxts_of_sproc_sshms sshms \<equiv> {ctxt. \<exists> hi flag. ((hi, ctxt),flag) \<in> sshms}"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   471
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   472
definition inherit_shms_check_s :: "security_context_t \<Rightarrow> t_sproc_sshm set \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   473
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   474
  "inherit_shms_check_s pctxt sshms \<equiv> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   475
     (\<forall> ctxt \<in> sectxts_of_sproc_sshms sshms. permission_check pctxt ctxt C_shm P_inherit)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   476
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   477
(*
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   478
fun info_flow_sshm :: "t_sproc \<Rightarrow> t_sproc \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   479
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   480
  "info_flow_sshm (pi,sec,fds,shms) (pi',sec',fds',shms') = 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   481
     (\<exists> sh flag'. (sh, SHM_RDWR) \<in> shms \<and> (sh, flag') \<in> shms')" 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   482
*)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   483
definition info_flow_sproc_sshms :: "t_sproc_sshm set \<Rightarrow> t_sproc_sshm set \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   484
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   485
  "info_flow_sproc_sshms shms shms' \<equiv> (\<exists> sh flag'. (sh, SHM_RDWR) \<in> shms \<and> (sh, flag') \<in> shms')" 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   486
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   487
fun info_flow_sshm :: "t_sproc \<Rightarrow> t_sproc \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   488
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   489
  "info_flow_sshm (pi,sec,fds,shms) (pi',sec',fds',shms') = info_flow_sproc_sshms shms shms'"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   490
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   491
definition update_ss_shms :: "t_static_state \<Rightarrow> t_sproc \<Rightarrow> bool \<Rightarrow> t_static_state"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   492
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   493
  "update_ss_shms ss spfrom tag \<equiv> {sobj. \<exists> sobj' \<in> ss. 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   494
     (case sobj' of 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   495
        S_proc sp tagp \<Rightarrow> if (info_flow_sshm spfrom sp) 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   496
                          then if (is_many_sproc sp)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   497
                               then (sobj = S_proc sp tagp \<or> sobj = S_proc sp (tagp \<or> tag))
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   498
                               else (sobj = S_proc sp (tagp \<or> tag))
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   499
                          else (sobj = S_proc sp tag)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   500
     | _ \<Rightarrow> sobj = sobj')}"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   501
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   502
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   503
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   504
(* all reachable static states(sobjects set) *)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   505
inductive_set static :: "t_static_state set"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   506
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   507
  s_init:    "init_static_state \<in> static"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   508
| s_execve:  "\<lbrakk>ss \<in> static; S_proc (pi, pctxt, fds, shms) tagp \<in> ss; S_file sfs tagf \<in> ss;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   509
               (fi,fsec,pfsec,asecs) \<in> sfs; npctxt_execve pctxt fsec = Some pctxt';
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   510
               grant_execve pctxt fsec pctxt'; search_check_s pctxt (fi,fsec,pfsec,asecs) True; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   511
               inherit_fds_check_s pctxt' fds'; fds' \<subseteq> fds\<rbrakk>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   512
  \<Longrightarrow> (update_ss ss (S_proc (pi, pctxt, fds, shms) tagp) 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   513
                    (S_proc (pi, pctxt', fds', {}) (tagp \<or> tagf))) \<in> static"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   514
| s_clone:   "\<lbrakk>ss \<in> static; S_proc (pi, pctxt, fds, shms) tagp \<in> ss; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   515
               permission_check pctxt pctxt C_process P_fork;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   516
               inherit_fds_check_s pctxt fds'; fds' \<subseteq> fds; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   517
               inherit_shms_check_s pctxt shms'; shms' \<subseteq> shms\<rbrakk>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   518
  \<Longrightarrow> (add_ss ss (S_proc (Created, pctxt, fds', shms') tagp)) \<in> static"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   519
| s_kill:    "\<lbrakk>ss \<in> static; S_proc (pi, pctxt, fds, shms) tagp \<in> ss; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   520
               S_proc (pi', pctxt', fds', shms') tagp' \<in> ss; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   521
               permission_check pctxt pctxt' C_process P_sigkill\<rbrakk>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   522
  \<Longrightarrow> (del_ss ss (S_proc (pi', pctxt', fds', shms') tagp')) \<in> static"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   523
| s_ptrace:  "\<lbrakk>ss \<in> static; S_proc sp tagp \<in> ss; S_proc sp' tagp' \<in> ss; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   524
               permission_check (sextxt_of_sproc sp) (sectxt_of_sproc sp') C_process P_ptrace\<rbrakk>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   525
  \<Longrightarrow> (update_ss_shms (update_ss_shms ss sp tagp) sp' tagp') \<in> static"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   526
| s_exit:    "\<lbrakk>ss \<in> static; S_proc sp tagp \<in> ss\<rbrakk> \<Longrightarrow> (del_ss ss (S_proc sp tagp)) \<in> static"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   527
| s_open:    "\<lbrakk>ss \<in> static; S_proc (pi, pctxt, fds, shms) tagp \<in> ss; S_file sfs tagf \<in> ss; sf \<in> sfs;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   528
              search_check_s pctxt sf True; \<not> is_creat_excl_flag flags; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   529
              oflags_check flags pctxt (sectxt_of_sfile sf); permission_check pctxt pctxt C_fd P_setattr\<rbrakk>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   530
  \<Longrightarrow> (update_ss ss (S_proc (pi, pctxt, fds, shms) tagp)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   531
                    (S_proc (pi, pctxt, fds \<union> {(pctxt,flags,sf)}, shms) tagp)) \<in> static"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   532
| s_open':   "\<lbrakk>ss \<in> static; S_proc (pi, pctxt, fds, shms) tagp \<in> ss; is_creat_excl_flag flags;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   533
               S_dir (pfi,fsec,pfsec,asecs) \<in> ss; search_check_s pctxt (pfi,fsec,pfsec,asecs) False; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   534
               nfsec = nfctxt_create pctxt fsec C_file; oflags_check flags pctxt nfsec;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   535
               permission_check pctxt fsec C_dir P_add_rename; permission_check pctxt pctxt C_fd P_setattr\<rbrakk>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   536
  \<Longrightarrow> (update_ss (add_ss ss (S_file {(Created, nfsec, Some fsec, asecs \<union> {fsec})} tagp))
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   537
         (S_proc (pi, pctxt, fds, shms) tagp)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   538
         (S_proc (pi, pctxt, fds \<union> {(pctxt, flags, (Created, nfsec, Some fsec, asecs \<union> {fsec}))}, shms) tagp)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   539
      ) \<in> static"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   540
| S_readf:   "\<lbrakk>ss \<in> static; S_proc (pi,pctxt,fds,shms) tagp \<in> ss; (fdctxt,flags,sf) \<in> fds; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   541
               permission_check pctxt fdctxt C_fd P_setattr; S_file sfs tagf \<in> ss; sf \<in> sfs;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   542
               permission_check pctxt (sectxt_of_sfile sf) C_file P_read; is_read_flag flags\<rbrakk>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   543
  \<Longrightarrow> (update_ss_shms ss (pi, pctxt,fds,shms) (tagp \<or> tagf)) \<in> static"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   544
| S_writef:  "\<lbrakk>ss \<in> static; S_proc (pi,pctxt,fds,shms) tagp \<in> ss; (fdctxt,flags,sf) \<in> fds; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   545
               permission_check pctxt fdctxt C_fd P_setattr; sf \<in> sfs; S_file sfs tagf \<in> ss; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   546
               permission_check pctxt (sectxt_of_sfile sf) C_file P_write; is_write_flag flags\<rbrakk>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   547
  \<Longrightarrow> (update_ss ss (S_file sfs tagf) (S_file sfs (tagp \<or> tagf))) \<in> static"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   548
| S_unlink:  "\<lbrakk>ss \<in> static; S_proc (pi,pctxt,fds,shms) tagp \<in> ss; S_file sfs tagf \<in> ss;  
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   549
               (Init f,fsec,Some pfsec,asecs) \<in> sfs; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   550
               search_check_s pctxt (Init f,fsec,Some pfsec,asecs) True; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   551
               permission_check pctxt fsec C_file P_unlink; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   552
               permission_check pctxt pfsec C_dir P_remove_name\<rbrakk>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   553
  \<Longrightarrow> ((ss - {S_file sfs tagf}) \<union> {S_file (sfs - {(Init f,fsec,Some pfsec,asecs)}) tagf}) \<in> static"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   554
| S_rmdir:   "\<lbrakk>ss \<in> static; S_proc (pi,pctxt,fds,shms) tagp \<in> ss; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   555
               S_dir (fi,fsec,Some pfsec,asecs) \<in> ss;  
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   556
               search_check_s pctxt (fi,fsec,Some pfsec,asecs) False; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   557
               permission_check pctxt fsec C_dir P_rmdir;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   558
               permission_check pctxt pfsec C_dir P_remove_name\<rbrakk>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   559
  \<Longrightarrow> (del_ss ss (S_dir (fi,fsec,Some pfsec,asecs))) \<in> static"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   560
| S_mkdir:   "\<lbrakk>ss \<in> static; S_proc (pi,pctxt,fds,shms) tagp \<in> ss; S_dir (fi,fsec,pfsec,asecs) \<in> ss;  
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   561
               search_check_s pctxt (fi,fsec,pfsec,asecs) False; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   562
               permission_check pctxt (nfctxt_create pctxt fsec C_dir) C_dir P_create;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   563
               permission_check pctxt fsec C_dir P_add_name\<rbrakk>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   564
  \<Longrightarrow> (add_ss ss (S_dir (Created,nfctxt_create pctxt fsec C_dir,Some fsec,asecs \<union> {fsec}))) \<in> static"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   565
| s_link:    "\<lbrakk>ss \<in> static; S_proc (pi,pctxt,fds,shms) tagp \<in> ss; S_dir (pfi,pfsec,ppfsec,asecs) \<in> ss;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   566
               S_file sfs tagf \<in> ss; sf \<in> sfs; nfsec = nfctxt_create pctxt pfsec C_file;  
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   567
               search_check_s pctxt (pfi,pfsec,ppfsec,asecs) False; search_check_s pctxt sf True;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   568
               permission_check pctxt (sectxt_of_sfile sf) C_file P_link; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   569
               permission_check pctxt pfsec C_dir P_add_name\<rbrakk>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   570
  \<Longrightarrow> (update_ss ss (S_file sfs tagf) 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   571
                  (S_file (sfs \<union> {(Created,nfsec,Some pfsec, asecs \<union> {pfsec})}) tagf)) \<in> static"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   572
| s_trunc:   "\<lbrakk>ss \<in> static; S_proc (pi,pctxt,fds,shms) tagp \<in> ss; S_file sfs tagf \<in> ss; sf \<in> sfs; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   573
               search_check_s pctxt sf True; permission_check pctxt (sectxt_of_sfile sf) C_file P_setattr\<rbrakk>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   574
  \<Longrightarrow> (update_ss ss (S_file sfs tagf) (S_file sfs (tagf \<or> tagp))) \<in> static"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   575
(*
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   576
| s_rename:  "\<lbrakk>ss \<in> static; S_proc (pi,pctxt,fds,shms) tagp \<in> ss; S_file sfs tagf \<in> ss;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   577
               (sf#spf') \<in> sfs; S_dir spf tagpf \<in> ss; \<not>((sf#spf') \<preceq> (sf#spf)); 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   578
               search_check_s pctxt spf False; search_check_s pctxt (sf#spf') True; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   579
               sectxt_of_sfile (sf#spf') = Some fctxt; sectxt_of_sfile spf = Some pfctxt;  
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   580
               permission_check pctxt fctxt C_file P_rename;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   581
               permission_check pctxt pfctxt C_dir P_add_name;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   582
               ss_rename ss (sf#spf') (sf#spf) ss'; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   583
               ss_rename_no_same_fname ss (sf#spf') (sf#spf)\<rbrakk>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   584
              \<Longrightarrow> ss' \<in> static"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   585
| s_rename': "\<lbrakk>ss \<in> static; S_proc (pi,pctxt,fds,shms) tagp \<in> ss; S_dir (sf#spf') tagf \<in> ss;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   586
               S_dir spf tagpf \<in> ss; \<not>((sf#spf') \<preceq> (sf#spf)); 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   587
               search_check_s pctxt spf False; search_check_s pctxt (sf#spf') True; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   588
               sectxt_of_sfile (sf#spf') = Some fctxt; sectxt_of_sfile spf = Some pfctxt;  
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   589
               permission_check pctxt fctxt C_dir P_reparent;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   590
               permission_check pctxt pfctxt C_dir P_add_name;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   591
               ss_rename ss (sf#spf') (sf#spf) ss'; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   592
               ss_rename_no_same_fname ss (sf#spf') (sf#spf)\<rbrakk>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   593
              \<Longrightarrow> ss' \<in> static"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   594
*)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   595
| s_createq: "\<lbrakk>ss \<in> static; S_proc (pi,pctxt,fds,shms) tagp \<in> ss; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   596
               permission_check pctxt pctxt C_msgq P_associate;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   597
               permission_check pctxt pctxt C_msgq P_create\<rbrakk>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   598
  \<Longrightarrow> (add_ss ss (S_msgq (Created,pctxt,[]))) \<in> static" 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   599
| s_sendmsg: "\<lbrakk>ss \<in> static; S_proc (pi,pctxt,fds,shms) tagp \<in> ss; S_msgq (qi,qctxt,sms) \<in> ss;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   600
               permission_check pctxt qctxt C_msgq P_enqueue;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   601
               permission_check pctxt qctxt C_msgq P_write; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   602
               permission_check pctxt pctxt C_msg  P_create\<rbrakk>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   603
  \<Longrightarrow> (update_ss ss (S_msgq (qi,qctxt,sms)) 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   604
                    (S_msgq (qi,qctxt,sms @ [(Created, pctxt, tagp)]))) \<in> static"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   605
| s_recvmsg: "\<lbrakk>ss \<in> static; S_proc (pi,pctxt,fds,shms) tagp \<in> ss; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   606
               S_msgq (qi,qctxt,(mi,mctxt,tagm)#sms) \<in> ss;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   607
               permission_check pctxt qctxt C_msgq P_read; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   608
               permission_check pctxt mctxt C_msg  P_receive\<rbrakk>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   609
  \<Longrightarrow> (update_ss_shms ss (pi,pctxt,fds,shms) (tagp \<or> tagm)) \<in> static"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   610
| s_removeq: "\<lbrakk>ss \<in> static; S_proc (pi,pctxt,fds,shms) tagp \<in> ss; S_msgq (qi,qctxt,sms) \<in> ss;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   611
               permission_check pctxt qctxt C_msgq P_destroy\<rbrakk>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   612
  \<Longrightarrow> (del_ss ss (S_msgq (qi,qctxt,sms))) \<in> static"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   613
| s_createh: "\<lbrakk>ss \<in> static; S_proc (pi,pctxt,fds,shms) tagp \<in> ss;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   614
               permission_check pctxt pctxt C_shm P_associate; 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   615
               permission_check pctxt pctxt C_shm P_create\<rbrakk>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   616
   \<Longrightarrow> (add_ss ss (S_shm (Created, pctxt))) \<in> static"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   617
| s_attach:  "\<lbrakk>ss \<in> static; S_proc (pi,pctxt,fds,shms) tagp \<in> ss; S_shm (hi,hctxt) \<in> ss;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   618
               if flag = SHM_RDONLY then permission_check pctxt hctxt C_shm P_read
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   619
               else (permission_check pctxt hctxt C_shm P_read \<and>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   620
                     permission_check pctxt hctxt C_shm P_write)\<rbrakk>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   621
   \<Longrightarrow> (update_ss ss (S_proc (pi,pctxt,fds,shms) tagp)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   622
                    (S_proc (pi,pctxt,fds,shms \<union> {((hi,hctxt),flag)}) tagp)) \<in> static"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   623
| s_detach:  "\<lbrakk>ss \<in> static; S_proc (pi,pctxt,fds,shms) tagp \<in> ss; S_shm sh \<in> ss;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   624
               (sh,flag) \<in> shms; \<not> is_many_sshm sh\<rbrakk>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   625
   \<Longrightarrow> (update_ss ss (S_proc (pi,pctxt,fds,shms) tagp)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   626
                    (S_proc (pi,pctxt,fds,shms - {(sh,flag)}) tagp)) \<in> static"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   627
| s_deleteh: "\<lbrakk>ss \<in> static; S_proc (pi,pctxt,fds,shms) tagp \<in> ss; S_shm (hi,hctxt) \<in> ss;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   628
               permission_check pctxt hctxt C_shm P_destroy; \<not> is_many_sshm sh\<rbrakk>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   629
   \<Longrightarrow> (remove_sproc_sshm (del_ss ss (S_shm (hi,hctxt))) (hi,hctxt)) \<in> static"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   630
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   631
(*
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   632
fun smsg_related :: "t_msg \<Rightarrow> t_smsg list \<Rightarrow> bool" 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   633
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   634
  "smsg_related m []                   = False" 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   635
| "smsg_related m ((mi, sec, tag)#sms) =  
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   636
    (if (mi = Init m) then True else smsg_related m sms)" 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   637
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   638
fun smsgq_smsg_related :: "t_msgq \<Rightarrow> t_msg \<Rightarrow> t_smsgq \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   639
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   640
  "smsgq_smsg_related q m (qi, sec, smsgslist) = ((qi = Init q) \<and> (smsg_related m smsgslist))"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   641
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   642
fun smsg_relatainted :: "t_msg \<Rightarrow> t_smsg list \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   643
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   644
  "smsg_relatainted m []                     = False"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   645
| "smsg_relatainted m ((mi, sec, tag)#sms) = 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   646
    (if (mi = Init m \<and> tag = True) then True else smsg_relatainted m sms)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   647
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   648
fun smsgq_smsg_relatainted :: "t_msgq \<Rightarrow> t_msg \<Rightarrow> t_smsgq \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   649
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   650
  "smsgq_smsg_relatainted q m (qi, sec, smsgslist) = 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   651
     ((qi = Init q) \<and> (smsg_relatainted m smsgslist))"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   652
*)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   653
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   654
fun sfile_related :: "t_sfile \<Rightarrow> t_file \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   655
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   656
  "sfile_related (fi,sec,psec,asecs) f = (fi = Init f)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   657
(*
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   658
fun sproc_related :: "t_process \<Rightarrow> t_sproc \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   659
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   660
  "sproc_related p (pi, sec, fds, shms) = (pi = Init p)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   661
*)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   662
fun init_obj_related :: "t_sobject \<Rightarrow> t_object \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   663
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   664
  "init_obj_related (S_proc (Init p, sec, fds, shms) tag) (O_proc p') = (p = p')"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   665
| "init_obj_related (S_file sfs tag) (O_file f) = (\<exists> sf \<in> sfs. sfile_related sf f)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   666
| "init_obj_related (S_dir sf) (O_dir f) = (sfile_related sf f)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   667
| "init_obj_related (S_msgq (Init q, sec, sms)) (O_msgq q') = (q = q')"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   668
| "init_obj_related (S_shm (Init h, sec)) (O_shm h') = (h = h')"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   669
| "init_obj_related (S_msg (Init q, sec, sms) (Init m, secm, tagm)) (O_msg q' m') = (q = q' \<and> m = m')"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   670
| "init_obj_related _ _ = False"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   671
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   672
fun tainted_s :: "t_static_state \<Rightarrow> t_sobject \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   673
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   674
  "tainted_s ss (S_proc sp  tag) = (S_proc sp tag  \<in> ss \<and> tag = True)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   675
| "tainted_s ss (S_file sfs tag) = (S_file sfs tag \<in> ss \<and> tag = True)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   676
| "tainted_s ss (S_msg  (qi, sec, sms)  (mi, secm, tag)) = 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   677
     (S_msgq (qi, sec, sms) \<in> ss \<and> (mi,sec,tag) \<in> set sms \<and> tag = True)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   678
| "tainted_s ss _ = False"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   679
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   680
(*
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   681
fun tainted_s :: "t_object \<Rightarrow> t_static_state \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   682
where 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   683
  "tainted_s (O_proc p)  ss = (\<exists> sp. S_proc sp True \<in> ss \<and> sproc_related p sp)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   684
| "tainted_s (O_file f)  ss = (\<exists> sfs sf. S_file sfs True \<in> ss \<and> sf \<in> sfs \<and> sfile_related f sf)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   685
| "tainted_s (O_msg q m) ss = (\<exists> sq. S_msgq sq \<in> ss \<and> smsgq_smsg_relatainted q m sq)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   686
| "tainted_s _           ss = False"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   687
*)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   688
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   689
definition taintable_s :: "t_object \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   690
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   691
  "taintable_s obj \<equiv> \<exists> ss \<in> static. \<exists> sobj. tainted_s ss sobj \<and> init_obj_related sobj obj \<and> init_alive obj"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   692
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   693
definition deletable_s :: "t_object \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   694
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   695
  "deletable_s obj \<equiv> init_alive obj \<and> (\<exists> ss \<in> static. \<forall> sobj \<in> ss. \<not> init_obj_related sobj obj)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   696
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   697
definition undeletable_s :: "t_object \<Rightarrow> bool"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   698
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   699
  "undeletable_s obj \<equiv> init_alive obj \<and> (\<forall> ss \<in> static. \<exists> sobj \<in> ss. init_obj_related sobj obj)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   700
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   701
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   702
(**************** translation from dynamic to static *******************)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   703
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   704
definition cf2sfile :: "t_state \<Rightarrow> t_file \<Rightarrow> bool \<Rightarrow> t_sfile option"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   705
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   706
  "cf2sfile s f Is_file \<equiv>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   707
     case (parent f) of 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   708
       None \<Rightarrow> if Is_file then None else Some sroot
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   709
     | Some pf \<Rightarrow> if Is_file 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   710
     then (case (sectxt_of_obj s (O_file f), sectxt_of_obj s (O_dir pf), get_parentfs_ctxts s pf) of
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   711
            (Some sec, Some psec, Some asecs) \<Rightarrow>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   712
 Some (if (\<not> deleted (O_file f) s \<and> is_init_file f) then Init f else Created, sec, Some psec, set asecs)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   713
          | _ \<Rightarrow> None) 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   714
     else (case (sectxt_of_obj s (O_dir f), sectxt_of_obj s (O_dir pf), get_parentfs_ctxts s pf) of
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   715
            (Some sec, Some psec, Some asecs) \<Rightarrow>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   716
 Some (if (\<not> deleted (O_dir f) s \<and> is_init_dir f) then Init f else Created, sec, Some psec, set asecs)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   717
          | _ \<Rightarrow> None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   718
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   719
definition cfs2sfiles :: "t_state \<Rightarrow> t_file set \<Rightarrow> t_sfile set"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   720
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   721
  "cfs2sfiles s fs \<equiv> {sf. \<exists> f \<in> fs. cf2sfile s f True = Some sf}"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   722
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   723
definition same_inode_files :: "t_state \<Rightarrow> t_file \<Rightarrow> t_file set"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   724
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   725
  "same_inode_files s f \<equiv> {f'. inum_of_file s f = inum_of_file s f'}"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   726
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   727
(* here cf2sfile is passed with True, because, process' fds are only for files not dirs *)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   728
definition cfd2sfd :: "t_state \<Rightarrow> t_process \<Rightarrow> t_fd \<Rightarrow> t_sfd option" 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   729
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   730
  "cfd2sfd s p fd \<equiv> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   731
    (case (file_of_proc_fd s p fd, flags_of_proc_fd s p fd, sectxt_of_obj s (O_fd p fd)) of
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   732
      (Some f, Some flags, Some sec) \<Rightarrow> (case (cf2sfile s f True) of 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   733
                                          Some sf \<Rightarrow> Some (sec, flags, sf)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   734
                                        | _       \<Rightarrow> None)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   735
    | _ \<Rightarrow> None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   736
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   737
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   738
definition cpfd2sfds :: "t_state \<Rightarrow> t_process \<Rightarrow> t_sfd set"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   739
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   740
  "cpfd2sfds s p \<equiv> {sfd. \<exists> fd sfd f. file_of_proc_fd s p fd = Some f \<and> cfd2sfd s p fd = Some sfd}"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   741
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   742
definition ch2sshm :: "t_state \<Rightarrow> t_shm \<Rightarrow> t_sshm option"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   743
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   744
  "ch2sshm s h \<equiv> (case (sectxt_of_obj s (O_shm h)) of
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   745
                    Some sec \<Rightarrow> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   746
 Some (if (\<not> deleted (O_shm h) s \<and> h \<in> init_shms) then Init h else Created, sec)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   747
                  | _ \<Rightarrow> None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   748
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   749
definition cph2spshs :: "t_state \<Rightarrow> t_process \<Rightarrow> t_sproc_sshm set"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   750
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   751
  "cph2spshs s p \<equiv> {(sh, flag) | sh flag h. (p, flag) \<in> procs_of_shm s h \<and> ch2sshm s h = Some sh}"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   752
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   753
definition cp2sproc :: "t_state \<Rightarrow> t_process \<Rightarrow> t_sproc option"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   754
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   755
  "cp2sproc s p \<equiv> (case (sectxt_of_obj s (O_proc p)) of 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   756
                     Some sec \<Rightarrow> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   757
 Some (if (\<not> deleted (O_proc p) s \<and> p \<in> init_procs) then Init p else Created, sec, 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   758
       cpfd2sfds s p, cph2spshs s p)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   759
                   | _ \<Rightarrow> None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   760
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   761
definition cm2smsg :: "t_state \<Rightarrow> t_msgq \<Rightarrow> t_msg \<Rightarrow> t_smsg option"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   762
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   763
  "cm2smsg s q m \<equiv> (case (sectxt_of_obj s (O_msg q m)) of 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   764
                      Some sec \<Rightarrow>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   765
 Some (if (\<not> deleted (O_msg q m) s \<and> m \<in> set (init_msgs_of_queue q)) then Init m else Created,
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   766
       sec, O_msg q m \<in> tainted s)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   767
                    | _ \<Rightarrow> None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   768
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   769
fun cqm2sms:: "t_state \<Rightarrow> t_msgq \<Rightarrow> t_msg list \<Rightarrow> (t_smsg list) option"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   770
where 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   771
  "cqm2sms s q [] = Some []"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   772
| "cqm2sms s q (m#ms) = 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   773
     (case (cqm2sms s q ms, cm2smsg s q m) of 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   774
       (Some sms, Some sm) \<Rightarrow> Some (sm#sms) 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   775
     | _ \<Rightarrow> None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   776
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   777
definition cq2smsgq :: "t_state \<Rightarrow> t_msgq \<Rightarrow> t_smsgq option"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   778
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   779
  "cq2smsgq s q \<equiv> (case (sectxt_of_obj s (O_msgq q), cqm2sms s q (msgs_of_queue s q)) of 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   780
                     (Some sec, Some sms) \<Rightarrow> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   781
 Some (if (\<not> deleted (O_msgq q) s \<and> q \<in> init_msgqs) then Init q else Created,
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   782
       sec, sms)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   783
                   | _ \<Rightarrow> None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   784
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   785
fun co2sobj :: "t_state \<Rightarrow> t_object \<Rightarrow> t_sobject option"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   786
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   787
  "co2sobj s (O_proc p) = 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   788
     (case (cp2sproc s p) of 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   789
        Some sp \<Rightarrow> Some (S_proc sp (O_proc p \<in> tainted s))
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   790
      | _       \<Rightarrow> None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   791
| "co2sobj s (O_file f) = 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   792
     (if (f \<in> current_files s) then 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   793
        Some (S_file (cfs2sfiles s (same_inode_files s f)) (O_file f \<in> tainted s))
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   794
      else None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   795
| "co2sobj s (O_dir f) = 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   796
     (case (cf2sfile s f False) of
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   797
        Some sf  \<Rightarrow> Some (S_dir sf)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   798
      | _ \<Rightarrow> None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   799
| "co2sobj s (O_msgq q) = 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   800
     (case (cq2smsgq s q) of
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   801
        Some sq \<Rightarrow> Some (S_msgq sq)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   802
      | _ \<Rightarrow> None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   803
| "co2sobj s (O_shm h) = 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   804
     (case (ch2sshm s h) of 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   805
        Some sh \<Rightarrow> Some (S_shm sh)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   806
      | _ \<Rightarrow> None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   807
| "co2sobj s (O_msg q m) = 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   808
     (case (cq2smsgq s q, cm2smsg s q m) of 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   809
       (Some sq, Some sm) \<Rightarrow> Some (S_msg sq sm)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   810
     | _ \<Rightarrow> None)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   811
| "co2sobj s _ = None"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   812
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   813
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   814
(***************** for backward proof when Instancing static objects ******************)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   815
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   816
definition next_nat :: "nat set \<Rightarrow> nat"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   817
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   818
  "next_nat nset = (Max nset) + 1"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   819
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   820
definition new_proc :: "t_state \<Rightarrow> t_process"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   821
where 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   822
  "new_proc \<tau> = next_nat (current_procs \<tau>)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   823
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   824
definition new_inode_num :: "t_state \<Rightarrow> nat"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   825
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   826
  "new_inode_num \<tau> = next_nat (current_inode_nums \<tau>)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   827
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   828
definition new_msgq :: "t_state \<Rightarrow> t_msgq"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   829
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   830
  "new_msgq s = next_nat (current_msgqs s)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   831
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   832
definition new_msg :: "t_state \<Rightarrow> t_msgq \<Rightarrow> nat"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   833
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   834
  "new_msg s q = next_nat (set (msgs_of_queue s q))"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   835
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   836
definition new_shm :: "t_state \<Rightarrow> nat"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   837
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   838
  "new_shm \<tau> = next_nat (current_shms \<tau>)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   839
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   840
definition new_proc_fd :: "t_state \<Rightarrow> t_process \<Rightarrow> t_fd"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   841
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   842
  "new_proc_fd \<tau> p = next_nat (current_proc_fds \<tau> p)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   843
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   844
definition all_fname_under_dir:: "t_file \<Rightarrow> t_state \<Rightarrow> t_fname set"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   845
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   846
  "all_fname_under_dir d \<tau> = {fn. \<exists> f. fn # d = f \<and> f \<in> current_files \<tau>}"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   847
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   848
fun fname_all_a:: "nat \<Rightarrow> t_fname"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   849
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   850
  "fname_all_a 0 = []" |
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   851
  "fname_all_a (Suc n) = ''a''@(fname_all_a n)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   852
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   853
definition fname_length_set :: "t_fname set \<Rightarrow> nat set"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   854
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   855
  "fname_length_set fns = length`fns"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   856
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   857
definition next_fname:: "t_file \<Rightarrow> t_state \<Rightarrow> t_fname"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   858
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   859
  "next_fname pf \<tau> = fname_all_a ((Max (fname_length_set (all_fname_under_dir pf \<tau>))) + 1)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   860
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   861
definition new_childf:: "t_file \<Rightarrow> t_state \<Rightarrow> t_file"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   862
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   863
  "new_childf pf \<tau> = next_fname pf \<tau> # pf"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   864
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   865
definition s2ss :: "t_state \<Rightarrow> t_static_state"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   866
where
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   867
  "s2ss s \<equiv> {sobj. \<exists> obj. alive s obj \<and> co2sobj s obj = Some sobj}"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   868
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   869
end
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   870
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   871
end