Current_sockets_prop.thy
author chunhan
Wed, 20 Nov 2013 15:19:58 +0800
changeset 70 002c34a6ff4f
parent 4 e9c5594d5963
permissions -rw-r--r--
add conflict of p fd as file_fd & socket
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
     1
theory Current_sockets_prop
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
     2
imports Main Flask Flask_type Current_files_prop
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
context flask begin
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
     6
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
     7
lemma cn_in_curp: "\<lbrakk>(p, fd) \<in> current_sockets \<tau>; valid \<tau>\<rbrakk> \<Longrightarrow> p \<in> current_procs \<tau>"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
     8
apply (induct \<tau>) defer
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
     9
apply (frule vd_cons, frule vt_grant_os, case_tac a)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    10
apply (auto simp:current_sockets_def inum_of_socket.simps current_procs.simps os_grant.simps split:if_splits option.splits
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    11
            dest:inos_has_sock_tag init_socket_has_inode)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    12
done
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    13
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    14
lemma cn_in_curfd_aux: "\<forall> p. (p, fd) \<in> current_sockets \<tau> \<and> valid \<tau> \<longrightarrow> fd \<in> current_proc_fds \<tau> p"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    15
apply (induct \<tau>) defer
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    16
apply (rule allI, rule impI, erule conjE, frule vd_cons, frule vt_grant_os, case_tac a)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    17
apply (auto simp:current_sockets_def current_proc_fds.simps os_grant.simps inum_of_socket.simps 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    18
            split:if_splits option.splits t_socket_af.splits dest:inos_has_sock_tag init_socket_has_inode)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    19
done
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    20
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    21
lemma cn_in_curfd: "\<lbrakk>(p, fd) \<in> current_sockets \<tau>; valid \<tau>\<rbrakk> \<Longrightarrow> fd \<in> current_proc_fds \<tau> p"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    22
by (simp add:cn_in_curfd_aux)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    23
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    24
lemma cn_in_curfd': "\<lbrakk>inum_of_socket \<tau> (p, fd) = Some im; valid \<tau>\<rbrakk> \<Longrightarrow> fd \<in> current_proc_fds \<tau> p"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    25
by (rule cn_in_curfd, simp_all add:current_sockets_def)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    26
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    27
lemma cn_in_curp': "\<lbrakk>inum_of_socket \<tau> (p, fd) = Some im; valid \<tau>\<rbrakk> \<Longrightarrow> p \<in> current_procs \<tau>"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    28
apply (rule cn_in_curp)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    29
by (auto simp:current_sockets_def)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    30
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    31
(***************** current_sockets simpset *****************)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    32
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    33
lemma current_sockets_nil: "current_sockets [] = init_sockets"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    34
apply (simp add:current_sockets_def inum_of_socket.simps)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    35
using init_socket_has_inode inos_has_sock_tag
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    36
by auto
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    37
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    38
lemma current_sockets_closefd: "current_sockets (CloseFd p fd # \<tau>) = current_sockets \<tau> - {(p, fd)}"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    39
by (auto simp add:current_sockets_def inum_of_socket.simps)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    40
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    41
lemma current_sockets_createsock: "current_sockets (CreateSock p aft st fd ino # \<tau>) = insert (p, fd) (current_sockets \<tau>)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    42
by (auto simp add:current_sockets_def inum_of_socket.simps)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    43
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    44
lemma current_sockets_accept: "current_sockets (Accept p fd addr lport' fd' ino # \<tau>) = insert (p, fd') (current_sockets \<tau>)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    45
by (auto simp add:current_sockets_def inum_of_socket.simps)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    46
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    47
lemma current_sockets_clone: "valid (Clone p p' fds shms # \<tau>) 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    48
  \<Longrightarrow> current_sockets (Clone p p' fds shms # \<tau>) = 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    49
      current_sockets \<tau> \<union> {(p', fd)| fd. (p, fd) \<in> current_sockets \<tau> \<and> fd \<in> fds}"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    50
apply (frule vd_cons, drule vt_grant_os)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    51
apply (auto simp add:os_grant.simps current_sockets_def inum_of_socket.simps split:if_splits
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    52
                dest:cn_in_curp')
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    53
done
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    54
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    55
lemma current_sockets_execve: "valid (Execve p f fds # \<tau>) 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    56
  \<Longrightarrow> current_sockets (Execve p f fds # \<tau>) = 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    57
      current_sockets \<tau> - {(p, fd)| fd. (p, fd) \<in> current_sockets \<tau> \<and> fd \<notin> fds}"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    58
apply (frule vd_cons, drule vt_grant_os)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    59
apply (auto simp add:os_grant.simps current_sockets_def inum_of_socket.simps split:if_splits
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    60
                dest:cn_in_curp')
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    61
done
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    62
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    63
lemma current_sockets_kill:  "current_sockets (Kill p p' # \<tau>) = current_sockets \<tau> - {(p', fd)| fd. (p', fd) \<in> current_sockets \<tau>}"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    64
by (auto simp add:current_sockets_def inum_of_socket.simps split:if_splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    65
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    66
lemma current_sockets_exit:  "current_sockets (Exit p # \<tau>) = current_sockets \<tau> - {(p, fd)| fd. (p, fd) \<in> current_sockets \<tau>}"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    67
by (auto simp add:current_sockets_def inum_of_socket.simps split:if_splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    68
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    69
lemma current_sockets_other:
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    70
  "\<lbrakk>\<forall> p fd. e \<noteq> CloseFd p fd;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    71
    \<forall> p aft st fd ino. e \<noteq> CreateSock  p aft st fd ino;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    72
    \<forall> p fd addr lport' fd' ino. e \<noteq> Accept p fd addr lport' fd' ino;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    73
    \<forall> p p' fds shms. e \<noteq> Clone p p' fds shms;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    74
    \<forall> p f fds. e \<noteq> Execve p f fds;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    75
    \<forall> p p'. e \<noteq> Kill p p';
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    76
    \<forall> p. e \<noteq> Exit p\<rbrakk> \<Longrightarrow> current_sockets (e # \<tau>) = current_sockets \<tau>"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    77
apply (case_tac e)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    78
by (auto simp add:current_sockets_def inum_of_socket.simps split:if_splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    79
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    80
lemmas current_sockets_simps = current_sockets_nil current_sockets_closefd current_sockets_createsock 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    81
                               current_sockets_accept current_sockets_execve current_sockets_clone
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    82
                               current_sockets_kill current_sockets_exit current_sockets_other
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    83
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    84
(********** is_tcp_sock simpset ***************)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    85
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    86
lemma is_tcp_sock_nil:
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    87
  "is_tcp_sock [] = is_init_tcp_sock"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    88
apply (rule ext)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    89
apply (auto simp add:is_init_tcp_sock_def is_tcp_sock_def init_inum_of_socket_props 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    90
                dest:init_socket_has_inode split:option.splits)       
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    91
done
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    92
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    93
lemma is_tcp_sock_closefd:
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    94
  "is_tcp_sock (CloseFd p fd # s) = (is_tcp_sock s) ((p, fd) := False)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    95
apply (rule ext)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    96
by (auto simp add:is_tcp_sock_def inum_of_socket.simps split:option.splits t_inode_tag.splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    97
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    98
lemma is_tcp_sock_createsock:
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
    99
  "valid (CreateSock p af st fd ino # s) \<Longrightarrow> is_tcp_sock (CreateSock p af st fd ino # s) = (
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   100
     case st of
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   101
       STREAM \<Rightarrow> (is_tcp_sock s) ((p, fd) := True)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   102
     | _      \<Rightarrow> is_tcp_sock s                    )"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   103
apply (frule vd_cons, frule vt_grant_os, rule ext)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   104
by (auto simp add:is_tcp_sock_def inum_of_socket.simps dest:ios's_im_in_cim cn_in_curfd'
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   105
            split:option.splits t_inode_tag.splits t_socket_type.splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   106
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   107
lemma is_tcp_sock_accept:
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   108
  "valid (Accept p fd addr lport fd' ino # s) 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   109
   \<Longrightarrow> is_tcp_sock (Accept p fd addr lport fd' ino # s) = (is_tcp_sock s) ((p,fd') := True)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   110
apply (frule vd_cons, frule vt_grant_os, rule ext)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   111
by (auto simp add:is_tcp_sock_def inum_of_socket.simps dest:ios's_im_in_cim cn_in_curfd'
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   112
            split:option.splits t_inode_tag.splits t_socket_type.splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   113
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   114
lemma is_tcp_sock_execve:
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   115
  "valid (Execve p f fds # s) \<Longrightarrow> is_tcp_sock (Execve p f fds # s) = (
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   116
     \<lambda> (p', fd). if (p' = p \<and> fd \<in> fds) then is_tcp_sock s (p, fd) 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   117
                 else if (p' = p) then False
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   118
                      else is_tcp_sock s (p', fd))"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   119
apply (frule vd_cons, frule vt_grant_os, rule ext, case_tac x)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   120
by (auto simp add:is_tcp_sock_def inum_of_socket.simps dest:ios's_im_in_cim cn_in_curfd'
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   121
            split:option.splits t_inode_tag.splits t_socket_type.splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   122
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   123
lemma is_tcp_sock_clone:
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   124
  "valid (Clone p p' fds shms # s) \<Longrightarrow> is_tcp_sock (Clone p p' fds shms # s) = (
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   125
     \<lambda> (p'', fd). if (p'' = p' \<and> fd \<in> fds) then is_tcp_sock s (p, fd) 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   126
                 else if (p'' = p') then False
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   127
                      else is_tcp_sock s (p'', fd))"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   128
apply (frule vd_cons, frule vt_grant_os, rule ext, case_tac x)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   129
by (auto simp add:is_tcp_sock_def inum_of_socket.simps dest:ios's_im_in_cim cn_in_curfd'
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   130
            split:option.splits t_inode_tag.splits t_socket_type.splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   131
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   132
lemma is_tcp_sock_kill:
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   133
  "valid (Kill p p' # s) \<Longrightarrow> is_tcp_sock (Kill p p' # s) = (
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   134
     \<lambda> (p'', fd). if (p'' = p') then False
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   135
                  else is_tcp_sock s (p'', fd))"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   136
apply (frule vd_cons, frule vt_grant_os, rule ext, case_tac x)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   137
by (auto simp add:is_tcp_sock_def inum_of_socket.simps dest:ios's_im_in_cim cn_in_curfd'
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   138
            split:option.splits t_inode_tag.splits t_socket_type.splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   139
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   140
lemma is_tcp_sock_exit:
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   141
  "valid (Exit p # s) \<Longrightarrow> is_tcp_sock (Exit p # s) = (
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   142
     \<lambda> (p', fd). if (p' = p) then False
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   143
                 else is_tcp_sock s (p', fd))"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   144
apply (frule vd_cons, frule vt_grant_os, rule ext, case_tac x)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   145
by (auto simp add:is_tcp_sock_def inum_of_socket.simps dest:ios's_im_in_cim cn_in_curfd'
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   146
            split:option.splits t_inode_tag.splits t_socket_type.splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   147
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   148
lemma is_tcp_sock_other:
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   149
  "\<lbrakk>valid (e # \<tau>);
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   150
    \<forall> p fd. e \<noteq> CloseFd p fd;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   151
    \<forall> p aft st fd ino. e \<noteq> CreateSock p aft st fd ino;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   152
    \<forall> p fd addr lport' fd' ino. e \<noteq> Accept p fd addr lport' fd' ino;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   153
    \<forall> p p' fds shms. e \<noteq> Clone p p' fds shms;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   154
    \<forall> p f fds. e \<noteq> Execve p f fds;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   155
    \<forall> p p'. e \<noteq> Kill p p';
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   156
    \<forall> p. e \<noteq> Exit p\<rbrakk> \<Longrightarrow> is_tcp_sock (e # \<tau>) = is_tcp_sock \<tau>"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   157
apply (frule vd_cons, frule vt_grant_os, rule ext, case_tac x, case_tac e)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   158
prefer 6 apply (case_tac option)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   159
by (auto simp add:is_tcp_sock_def inum_of_socket.simps dest:ios's_im_in_cim cn_in_curfd'
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   160
            split:option.splits t_inode_tag.splits t_socket_type.splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   161
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   162
lemmas is_tcp_sock_simps = is_tcp_sock_nil is_tcp_sock_closefd is_tcp_sock_createsock is_tcp_sock_accept
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   163
  is_tcp_sock_clone is_tcp_sock_execve is_tcp_sock_kill is_tcp_sock_exit is_tcp_sock_other
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   164
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   165
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   166
(************ is_udp_sock simpset *************)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   167
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   168
lemma is_udp_sock_nil:
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   169
  "is_udp_sock [] = is_init_udp_sock"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   170
apply (rule ext)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   171
apply (auto simp add:is_init_udp_sock_def is_udp_sock_def init_inum_of_socket_props 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   172
                dest:init_socket_has_inode split:option.splits)       
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   173
done
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   174
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   175
lemma is_udp_sock_closefd:
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   176
  "is_udp_sock (CloseFd p fd # s) = (is_udp_sock s) ((p, fd) := False)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   177
apply (rule ext)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   178
by (auto simp add:is_udp_sock_def inum_of_socket.simps split:option.splits t_inode_tag.splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   179
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   180
lemma is_udp_sock_createsock:
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   181
  "valid (CreateSock p af st fd ino # s) \<Longrightarrow> is_udp_sock (CreateSock p af st fd ino # s) = (
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   182
     case st of
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   183
       DGRAM \<Rightarrow> (is_udp_sock s) ((p, fd) := True)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   184
     | _      \<Rightarrow> is_udp_sock s                    )"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   185
apply (frule vd_cons, frule vt_grant_os, rule ext)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   186
by (auto simp add:is_udp_sock_def inum_of_socket.simps dest:ios's_im_in_cim cn_in_curfd'
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   187
            split:option.splits t_inode_tag.splits t_socket_type.splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   188
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   189
lemma is_udp_sock_execve:
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   190
  "valid (Execve p f fds # s) \<Longrightarrow> is_udp_sock (Execve p f fds # s) = (
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   191
     \<lambda> (p', fd). if (p' = p \<and> fd \<in> fds) then is_udp_sock s (p, fd) 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   192
                 else if (p' = p) then False
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   193
                      else is_udp_sock s (p', fd))"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   194
apply (frule vd_cons, frule vt_grant_os, rule ext, case_tac x)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   195
by (auto simp add:is_udp_sock_def inum_of_socket.simps dest:ios's_im_in_cim cn_in_curfd'
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   196
            split:option.splits t_inode_tag.splits t_socket_type.splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   197
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   198
lemma is_udp_sock_clone:
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   199
  "valid (Clone p p' fds shms # s) \<Longrightarrow> is_udp_sock (Clone p p' fds shms # s) = (
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   200
     \<lambda> (p'', fd). if (p'' = p' \<and> fd \<in> fds) then is_udp_sock s (p, fd) 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   201
                 else if (p'' = p') then False
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   202
                      else is_udp_sock s (p'', fd))"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   203
apply (frule vd_cons, frule vt_grant_os, rule ext, case_tac x)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   204
by (auto simp add:is_udp_sock_def inum_of_socket.simps dest:ios's_im_in_cim cn_in_curfd'
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   205
            split:option.splits t_inode_tag.splits t_socket_type.splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   206
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   207
lemma is_udp_sock_kill:
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   208
  "valid (Kill p p' # s) \<Longrightarrow> is_udp_sock (Kill p p' # s) = (
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   209
     \<lambda> (p'', fd). if (p'' = p') then False
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   210
                  else is_udp_sock s (p'', fd))"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   211
apply (frule vd_cons, frule vt_grant_os, rule ext, case_tac x)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   212
by (auto simp add:is_udp_sock_def inum_of_socket.simps dest:ios's_im_in_cim cn_in_curfd'
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   213
            split:option.splits t_inode_tag.splits t_socket_type.splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   214
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   215
lemma is_udp_sock_exit:
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   216
  "valid (Exit p # s) \<Longrightarrow> is_udp_sock (Exit p # s) = (
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   217
     \<lambda> (p', fd). if (p' = p) then False
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   218
                 else is_udp_sock s (p', fd))"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   219
apply (frule vd_cons, frule vt_grant_os, rule ext, case_tac x)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   220
by (auto simp add:is_udp_sock_def inum_of_socket.simps dest:ios's_im_in_cim cn_in_curfd'
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   221
            split:option.splits t_inode_tag.splits t_socket_type.splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   222
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   223
lemma is_udp_sock_other:
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   224
  "\<lbrakk>valid (e # \<tau>);
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   225
    \<forall> p fd. e \<noteq> CloseFd p fd;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   226
    \<forall> p aft st fd ino. e \<noteq> CreateSock p aft st fd ino;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   227
    \<forall> p p' fds shms. e \<noteq> Clone p p' fds shms;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   228
    \<forall> p f fds. e \<noteq> Execve p f fds;
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   229
    \<forall> p p'. e \<noteq> Kill p p';
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   230
    \<forall> p. e \<noteq> Exit p\<rbrakk> \<Longrightarrow> is_udp_sock (e # \<tau>) = is_udp_sock \<tau>"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   231
apply (frule vd_cons, frule vt_grant_os, rule ext, case_tac x, case_tac e)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   232
prefer 6 apply (case_tac option)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   233
by (auto simp add:is_udp_sock_def inum_of_socket.simps dest:ios's_im_in_cim cn_in_curfd'
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   234
            split:option.splits t_inode_tag.splits t_socket_type.splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   235
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   236
lemmas is_udp_sock_simps = is_udp_sock_nil is_udp_sock_closefd is_udp_sock_createsock
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   237
  is_udp_sock_clone is_udp_sock_execve is_udp_sock_kill is_udp_sock_exit is_udp_sock_other
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   238
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   239
lemma update_with_shuthow_someI: "socket_in_trans \<tau> s \<Longrightarrow> \<exists> st'. update_with_shuthow (socket_state \<tau> s) how = Some st'"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   240
apply (case_tac "socket_state \<tau> s", simp add:socket_in_trans_def, case_tac a)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   241
apply (auto simp:update_with_shuthow.simps socket_in_trans_def split:option.splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   242
apply (case_tac t_sock_trans_state, case_tac [!] how)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   243
by auto
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   244
4
e9c5594d5963 fixed bugs in deleted definition
chunhan
parents: 1
diff changeset
   245
lemma is_tcp_sock_imp_curernt_proc:
e9c5594d5963 fixed bugs in deleted definition
chunhan
parents: 1
diff changeset
   246
  "\<lbrakk>is_tcp_sock s (p,fd); valid s\<rbrakk> \<Longrightarrow> p \<in> current_procs s"
e9c5594d5963 fixed bugs in deleted definition
chunhan
parents: 1
diff changeset
   247
apply (induct s)
e9c5594d5963 fixed bugs in deleted definition
chunhan
parents: 1
diff changeset
   248
apply (simp add:is_tcp_sock_nil is_init_tcp_sock_prop3)
e9c5594d5963 fixed bugs in deleted definition
chunhan
parents: 1
diff changeset
   249
apply (frule vd_cons, frule vt_grant_os, case_tac a)
e9c5594d5963 fixed bugs in deleted definition
chunhan
parents: 1
diff changeset
   250
by (auto simp:is_tcp_sock_simps split:if_splits option.splits t_socket_type.splits)
e9c5594d5963 fixed bugs in deleted definition
chunhan
parents: 1
diff changeset
   251
e9c5594d5963 fixed bugs in deleted definition
chunhan
parents: 1
diff changeset
   252
lemma is_udp_sock_imp_curernt_proc:
e9c5594d5963 fixed bugs in deleted definition
chunhan
parents: 1
diff changeset
   253
  "\<lbrakk>is_udp_sock s (p,fd); valid s\<rbrakk> \<Longrightarrow> p \<in> current_procs s"
e9c5594d5963 fixed bugs in deleted definition
chunhan
parents: 1
diff changeset
   254
apply (induct s)
e9c5594d5963 fixed bugs in deleted definition
chunhan
parents: 1
diff changeset
   255
apply (simp add:is_udp_sock_nil is_init_udp_sock_prop3)
e9c5594d5963 fixed bugs in deleted definition
chunhan
parents: 1
diff changeset
   256
apply (frule vd_cons, frule vt_grant_os, case_tac a)
e9c5594d5963 fixed bugs in deleted definition
chunhan
parents: 1
diff changeset
   257
by (auto simp:is_udp_sock_simps split:if_splits option.splits t_socket_type.splits)
e9c5594d5963 fixed bugs in deleted definition
chunhan
parents: 1
diff changeset
   258
e9c5594d5963 fixed bugs in deleted definition
chunhan
parents: 1
diff changeset
   259
1
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   260
(***** below should be adjusted after starting static analysis of sockets ! ??? ****)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   261
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   262
(*
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   263
lemma cn_has_sockstate: "\<lbrakk>(p, fd) \<in> current_sockets \<tau>; valid \<tau>\<rbrakk> \<Longrightarrow> socket_state \<tau> (p, fd) \<noteq> None"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   264
apply (induct \<tau> arbitrary: p) using init_socket_has_state
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   265
apply (simp add:current_sockets_simps socket_state.simps bidirect_in_init_def)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   266
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   267
apply (frule vd_cons, frule vt_grant_os, case_tac a)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   268
apply (auto simp:current_sockets_simps os_grant.simps socket_state.simps intro:update_with_shuthow_someI dest:cn_no_newproc' split:option.splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   269
done
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   270
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   271
lemma after_bind_update: "\<lbrakk>after_bind (update_with_shuthow (socket_state \<tau> s) t_shutdown_how); valid \<tau>\<rbrakk> \<Longrightarrow> after_bind (socket_state \<tau> s)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   272
apply (case_tac "socket_state \<tau> s", simp, case_tac a)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   273
apply (auto simp:update_with_shuthow.simps split:option.splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   274
done
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   275
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   276
lemma after_bind_has_laddr_aux: "\<forall> p fd. after_bind (socket_state \<tau> (p, fd)) \<and> valid \<tau> \<longrightarrow> (\<exists> ip port. local_addr \<tau> (p, fd) = Some (INET_ADDR ip port))"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   277
apply (induct \<tau>)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   278
apply (clarsimp simp add:socket_state.simps local_addr.simps)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   279
apply (drule init_socket_has_laddr, simp, erule exE)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   280
apply (case_tac y, simp)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   281
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   282
apply (clarify, frule vd_cons, frule vt_grant_os, case_tac a)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   283
apply (auto simp:socket_state.simps local_addr.simps os_grant.simps dest:after_bind_update split:if_splits option.splits t_sock_addr.splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   284
apply (erule_tac x = nat1 in allE, erule_tac x = nat2 in allE, erule impE, simp+)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   285
done
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   286
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   287
lemma after_bind_has_laddr: "\<lbrakk>after_bind (socket_state \<tau> (p, fd)); valid \<tau>\<rbrakk> \<Longrightarrow> \<exists> ip port. local_addr \<tau> (p, fd) = Some (INET_ADDR ip port)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   288
by (rule after_bind_has_laddr_aux[rule_format], simp+)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   289
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   290
lemma after_bind_has_laddr': "\<lbrakk>after_bind (socket_state \<tau> s); valid \<tau>\<rbrakk> \<Longrightarrow> \<exists> ip port. local_addr \<tau> s = Some (INET_ADDR ip port)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   291
by (case_tac s, auto dest:after_bind_has_laddr)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   292
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   293
lemma after_bind_has_laddr_D: "\<lbrakk>local_addr \<tau> s = None; valid \<tau>\<rbrakk> \<Longrightarrow> \<not> after_bind (socket_state \<tau> s)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   294
by (auto dest:after_bind_has_laddr')
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   295
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   296
lemma local_addr_valid: "\<lbrakk>local_addr \<tau> (p, fd) = Some (INET_ADDR ip port); (p, fd) \<in> current_sockets \<tau>; valid \<tau>\<rbrakk> \<Longrightarrow> ip \<in> local_ipaddrs"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   297
apply (induct \<tau> arbitrary:p fd port)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   298
apply (simp add:local_addr.simps current_sockets_simps local_ip_valid)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   299
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   300
apply (frule vd_cons, frule vt_grant_os, case_tac a)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   301
apply (auto simp:current_sockets_simps local_addr.simps os_grant.simps split:if_splits option.splits t_sock_addr.splits dest:cn_no_newproc' after_bind_has_laddr_D)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   302
done
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   303
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   304
lemma local_addr_valid': "\<lbrakk>local_addr \<tau> s = Some (INET_ADDR ip port); s \<in> current_sockets \<tau>; valid \<tau>\<rbrakk> \<Longrightarrow> ip \<in> local_ipaddrs"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   305
by (case_tac s, simp add:local_addr_valid)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   306
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   307
lemma local_ip_has_dev_D: "\<lbrakk>local_ip2dev ip = None; local_addr \<tau> s = Some (INET_ADDR ip port); s \<in> current_sockets \<tau>; valid \<tau>\<rbrakk> \<Longrightarrow> False"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   308
using local_ip2dev_valid
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   309
by (drule_tac local_addr_valid', simp+)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   310
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   311
lemma after_bind_has_netdev: "\<lbrakk>after_bind (socket_state \<tau> s); s \<in> current_sockets \<tau>; valid \<tau>\<rbrakk> \<Longrightarrow> \<exists> dev. netdev_of_socket \<tau> s = Some dev"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   312
apply (drule after_bind_has_laddr', simp, clarsimp)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   313
apply (frule local_addr_valid', simp+)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   314
apply (drule local_ip2dev_valid, simp add:netdev_of_socket_def)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   315
done
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   316
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   317
lemma after_bind_has_netdev_D: "\<lbrakk>netdev_of_socket \<tau> s = None; s \<in> current_sockets \<tau>; valid \<tau>\<rbrakk> \<Longrightarrow> \<not> after_bind (socket_state \<tau> s)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   318
by (auto dest:after_bind_has_netdev)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   319
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   320
lemma after_conacc_update: "\<lbrakk>after_conacc (update_with_shuthow (socket_state \<tau> s) t_shutdown_how); valid \<tau>\<rbrakk> \<Longrightarrow> after_conacc (socket_state \<tau> s)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   321
apply (case_tac "socket_state \<tau> s", simp, case_tac a)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   322
apply (auto simp:update_with_shuthow.simps split:option.splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   323
done
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   324
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   325
lemma after_conacc_has_raddr: "\<lbrakk>after_conacc (socket_state \<tau> (p, fd)); valid \<tau>\<rbrakk> \<Longrightarrow> \<exists> addr. remote_addr \<tau> (p, fd) = Some addr" 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   326
apply (induct \<tau> arbitrary:p fd)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   327
apply (simp add:socket_state.simps local_addr.simps) using init_socket_has_raddr apply blast
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   328
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   329
apply (frule vd_cons, frule vt_grant_os, case_tac a)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   330
apply (auto simp:socket_state.simps local_addr.simps os_grant.simps dest:after_conacc_update split:if_splits option.splits t_sock_addr.splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   331
done
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   332
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   333
lemma after_conacc_has_raddr': "\<lbrakk>after_conacc (socket_state \<tau> s); valid \<tau>\<rbrakk> \<Longrightarrow> \<exists> addr. remote_addr \<tau> s = Some addr"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   334
by (case_tac s, auto dest:after_conacc_has_raddr)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   335
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   336
lemma after_conacc_has_raddr_D: "\<lbrakk>remote_addr \<tau> s = None; valid \<tau>\<rbrakk> \<Longrightarrow> \<not> after_conacc (socket_state \<tau> s)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   337
by (auto dest:after_conacc_has_raddr')
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   338
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   339
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   340
lemma cn_has_socktype: "\<lbrakk>(p, fd) \<in> current_sockets \<tau>; valid \<tau>\<rbrakk> \<Longrightarrow> \<exists> st. socket_type \<tau> (p, fd) = Some st"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   341
apply (induct \<tau> arbitrary:p fd)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   342
using init_socket_has_socktype 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   343
apply (simp add:socket_type.simps current_sockets_nil bidirect_in_init_def) 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   344
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   345
apply (frule vd_cons, frule vt_grant_os, case_tac a)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   346
apply (auto simp:socket_type.simps current_sockets_simps os_grant.simps dest:cn_no_newproc' split:if_splits option.splits t_sock_addr.splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   347
done
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   348
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   349
lemma accept_has_temps: "Accept p fd\<^isub>1 addr port fd\<^isub>2 inum # valid \<tau> \<Longrightarrow> \<exists> temp. nettemp_of_socket (Accept p fd\<^isub>1 addr port fd\<^isub>2 inum # \<tau>) (p, fd\<^isub>2) is_remote = Some temp"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   350
apply (frule vd_cons, frule vt_grant_os)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   351
apply (auto dest:cn_has_socktype simp:os_grant.simps nettemp_of_socket_def netdev_of_socket_def 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   352
           dest!:after_conacc_has_raddr_D after_bind_has_laddr_D local_ip_has_dev_D
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   353
             simp:socket_state.simps split:if_splits option.splits t_sock_addr.splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   354
done
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   355
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   356
lemma accept_has_temps': 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   357
  "Accept p fd\<^isub>1 addr port fd\<^isub>2 inum # valid \<tau> 
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   358
   \<Longrightarrow> (\<exists> ltemp. nettemp_of_socket (Accept p fd\<^isub>1 addr port fd\<^isub>2 inum # \<tau>) (p, fd\<^isub>2) False = Some ltemp) \<and>
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   359
       (\<exists> rtemp. nettemp_of_socket (Accept p fd\<^isub>1 addr port fd\<^isub>2 inum # \<tau>) (p, fd\<^isub>2) True = Some rtemp)"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   360
apply (frule accept_has_temps[where is_remote = True])
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   361
apply (frule accept_has_temps[where is_remote = False])
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   362
by auto
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   363
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   364
lemma bind_has_ltemp: "Bind p fd addr # valid \<tau> \<Longrightarrow> \<exists> temp. nettemp_of_socket (Bind p fd addr # \<tau>) (p, fd) False = Some temp"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   365
apply (frule vd_cons, frule vt_grant_os)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   366
apply (auto dest:cn_has_socktype simp:os_grant.simps current_sockets_simps nettemp_of_socket_def dest!:after_bind_has_netdev_D after_bind_has_laddr_D
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   367
             simp:socket_state.simps split:if_splits option.splits t_sock_addr.splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   368
done
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   369
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   370
lemma connect_has_rtemp: "Connect p fd addr # valid \<tau> \<Longrightarrow> \<exists> temp. nettemp_of_socket (Connect p fd addr # \<tau>) (p, fd) True = Some temp"
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   371
apply (frule vd_cons, frule vt_grant_os)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   372
apply (auto dest:cn_has_socktype simp:os_grant.simps current_sockets_simps nettemp_of_socket_def dest!:after_bind_has_netdev_D after_bind_has_laddr_D
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   373
             simp:socket_state.simps split:if_splits option.splits t_sock_addr.splits)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   374
done
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   375
*)
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   376
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   377
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   378
end
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   379
7d9c0ed02b56 thy files
chunhan
parents:
diff changeset
   380
end