diff --git a/policy-F15.patch b/policy-F15.patch
index b54784f..64e3f90 100644
--- a/policy-F15.patch
+++ b/policy-F15.patch
@@ -5941,10 +5941,10 @@ index 0000000..15778fd
+# No types are sandbox_exec_t
diff --git a/policy/modules/apps/sandbox.if b/policy/modules/apps/sandbox.if
new file mode 100644
-index 0000000..402027a
+index 0000000..0c411b4
--- /dev/null
+++ b/policy/modules/apps/sandbox.if
-@@ -0,0 +1,340 @@
+@@ -0,0 +1,334 @@
+
+## policy for sandbox
+
@@ -6084,11 +6084,6 @@ index 0000000..402027a
+ manage_fifo_files_pattern($1_t, $1_file_t, $1_file_t)
+ manage_sock_files_pattern($1_t, $1_file_t, $1_file_t)
+
-+ type $1_devpts_t;
-+ term_pty($1_devpts_t)
-+ term_create_pty($1_t, $1_devpts_t)
-+ allow $1_t $1_devpts_t:chr_file { rw_chr_file_perms setattr };
-+
+ # window manager
+ miscfiles_setattr_fonts_cache_dirs($1_t)
+ allow $1_t self:capability setuid;
@@ -6100,14 +6095,13 @@ index 0000000..402027a
+ type $1_client_tmpfs_t, sandbox_tmpfs_type;
+ files_tmpfs_file($1_client_tmpfs_t)
+
-+ term_search_ptys($1_t)
-+ allow $1_client_t sandbox_devpts_t:chr_file { rw_term_perms setattr };
-+ term_create_pty($1_client_t,sandbox_devpts_t)
-+
+ manage_files_pattern($1_client_t, $1_client_tmpfs_t, $1_client_tmpfs_t)
++ manage_files_pattern($1_t, $1_client_tmpfs_t, $1_client_tmpfs_t)
+ fs_tmpfs_filetrans($1_client_t, $1_client_tmpfs_t, file )
++ fs_tmpfs_filetrans($1_t, $1_client_tmpfs_t, file )
+ # Pulseaudio tmpfs files with different MCS labels
+ dontaudit $1_client_t $1_client_tmpfs_t:file { read write };
++ dontaudit $1_t $1_client_tmpfs_t:file { read write };
+ allow sandbox_xserver_t $1_client_tmpfs_t:file { read write };
+
+ domtrans_pattern($1_t, xserver_exec_t, sandbox_xserver_t)
@@ -6287,10 +6281,10 @@ index 0000000..402027a
+')
diff --git a/policy/modules/apps/sandbox.te b/policy/modules/apps/sandbox.te
new file mode 100644
-index 0000000..6522c1b
+index 0000000..6b46acd
--- /dev/null
+++ b/policy/modules/apps/sandbox.te
-@@ -0,0 +1,441 @@
+@@ -0,0 +1,448 @@
+policy_module(sandbox,1.0.0)
+dbus_stub()
+attribute sandbox_domain;
@@ -6454,6 +6448,9 @@ index 0000000..6522c1b
+allow sandbox_x_domain sandbox_xserver_t:unix_stream_socket connectto;
+dontaudit sandbox_x_domain self:netlink_audit_socket { create_netlink_socket_perms nlmsg_relay };
+
++allow sandbox_x_domain sandbox_devpts_t:chr_file { rw_term_perms setattr };
++term_create_pty(sandbox_x_domain,sandbox_devpts_t)
++
+domain_dontaudit_read_all_domains_state(sandbox_x_domain)
+
+files_search_home(sandbox_x_domain)
@@ -6491,6 +6488,7 @@ index 0000000..6522c1b
+
+term_getattr_pty_fs(sandbox_x_domain)
+term_use_ptmx(sandbox_x_domain)
++term_search_ptys(sandbox_x_domain)
+
+application_dontaudit_signal(sandbox_x_domain)
+application_dontaudit_sigkill(sandbox_x_domain)
@@ -6543,6 +6541,7 @@ index 0000000..6522c1b
+ fs_read_nfs_files(sandbox_xserver_t)
+ fs_manage_nfs_dirs(sandbox_x_domain)
+ fs_manage_nfs_files(sandbox_x_domain)
++ fs_exec_nfs_files(sandbox_x_domain)
+')
+
+tunable_policy(`use_samba_home_dirs',`
@@ -6550,6 +6549,7 @@ index 0000000..6522c1b
+ fs_read_cifs_files(sandbox_xserver_t)
+ fs_manage_cifs_dirs(sandbox_x_domain)
+ fs_manage_cifs_files(sandbox_x_domain)
++ fs_exec_cifs_files(sandbox_x_domain)
+')
+
+tunable_policy(`use_fusefs_home_dirs',`
@@ -6557,6 +6557,7 @@ index 0000000..6522c1b
+ fs_read_fusefs_files(sandbox_xserver_t)
+ fs_manage_fusefs_dirs(sandbox_x_domain)
+ fs_manage_fusefs_files(sandbox_x_domain)
++ fs_exec_fusefs_files(sandbox_x_domain)
+')
+
+files_search_home(sandbox_x_t)
@@ -9947,7 +9948,7 @@ index 59bae6a..2e55e71 100644
+/dev/hugepages -d gen_context(system_u:object_r:hugetlbfs_t,s0)
+/dev/hugepages(/.*)? <>
diff --git a/policy/modules/kernel/filesystem.if b/policy/modules/kernel/filesystem.if
-index dfe361a..f296623 100644
+index dfe361a..496954e 100644
--- a/policy/modules/kernel/filesystem.if
+++ b/policy/modules/kernel/filesystem.if
@@ -646,11 +646,31 @@ interface(`fs_search_cgroup_dirs',`
@@ -10124,7 +10125,34 @@ index dfe361a..f296623 100644
## Create, read, write, and delete dirs
## on a DOS filesystem.
##
-@@ -1931,7 +2014,26 @@ interface(`fs_read_fusefs_symlinks',`
+@@ -1892,6 +1975,26 @@ interface(`fs_manage_fusefs_files',`
+
+ ########################################
+ ##
++## Execute files on a FUSEFS filesystem.
++##
++##
++##
++## Domain allowed access.
++##
++##
++##
++#
++interface(`fs_exec_fusefs_files',`
++ gen_require(`
++ type fusefs_t;
++ ')
++
++ allow $1 fusefs_t:dir list_dir_perms;
++ exec_files_pattern($1, fusefs_t, fusefs_t)
++')
++
++########################################
++##
+ ## Do not audit attempts to create,
+ ## read, write, and delete files
+ ## on a FUSEFS filesystem.
+@@ -1931,7 +2034,26 @@ interface(`fs_read_fusefs_symlinks',`
########################################
##
@@ -10152,7 +10180,7 @@ index dfe361a..f296623 100644
##
##
##
-@@ -1946,6 +2048,41 @@ interface(`fs_rw_hugetlbfs_files',`
+@@ -1946,6 +2068,41 @@ interface(`fs_rw_hugetlbfs_files',`
rw_files_pattern($1, hugetlbfs_t, hugetlbfs_t)
')
@@ -10194,7 +10222,7 @@ index dfe361a..f296623 100644
########################################
##
-@@ -1999,6 +2136,7 @@ interface(`fs_list_inotifyfs',`
+@@ -1999,6 +2156,7 @@ interface(`fs_list_inotifyfs',`
')
allow $1 inotifyfs_t:dir list_dir_perms;
@@ -10202,7 +10230,7 @@ index dfe361a..f296623 100644
')
########################################
-@@ -2331,6 +2469,7 @@ interface(`fs_read_nfs_files',`
+@@ -2331,6 +2489,7 @@ interface(`fs_read_nfs_files',`
type nfs_t;
')
@@ -10210,7 +10238,7 @@ index dfe361a..f296623 100644
allow $1 nfs_t:dir list_dir_perms;
read_files_pattern($1, nfs_t, nfs_t)
')
-@@ -2369,6 +2508,7 @@ interface(`fs_write_nfs_files',`
+@@ -2369,6 +2528,7 @@ interface(`fs_write_nfs_files',`
type nfs_t;
')
@@ -10218,7 +10246,7 @@ index dfe361a..f296623 100644
allow $1 nfs_t:dir list_dir_perms;
write_files_pattern($1, nfs_t, nfs_t)
')
-@@ -2395,6 +2535,25 @@ interface(`fs_exec_nfs_files',`
+@@ -2395,6 +2555,25 @@ interface(`fs_exec_nfs_files',`
########################################
##
@@ -10244,7 +10272,7 @@ index dfe361a..f296623 100644
## Append files
## on a NFS filesystem.
##
-@@ -2435,6 +2594,24 @@ interface(`fs_dontaudit_append_nfs_files',`
+@@ -2435,6 +2614,24 @@ interface(`fs_dontaudit_append_nfs_files',`
########################################
##
@@ -10269,7 +10297,7 @@ index dfe361a..f296623 100644
## Do not audit attempts to read or
## write files on a NFS filesystem.
##
-@@ -2449,7 +2626,7 @@ interface(`fs_dontaudit_rw_nfs_files',`
+@@ -2449,7 +2646,7 @@ interface(`fs_dontaudit_rw_nfs_files',`
type nfs_t;
')
@@ -10278,7 +10306,7 @@ index dfe361a..f296623 100644
')
########################################
-@@ -2637,6 +2814,24 @@ interface(`fs_dontaudit_read_removable_files',`
+@@ -2637,6 +2834,24 @@ interface(`fs_dontaudit_read_removable_files',`
########################################
##
@@ -10303,7 +10331,7 @@ index dfe361a..f296623 100644
## Read removable storage symbolic links.
##
##
-@@ -2653,6 +2848,25 @@ interface(`fs_read_removable_symlinks',`
+@@ -2653,6 +2868,25 @@ interface(`fs_read_removable_symlinks',`
read_lnk_files_pattern($1, removable_t, removable_t)
')
@@ -10329,7 +10357,7 @@ index dfe361a..f296623 100644
########################################
##
## Read and write block nodes on removable filesystems.
-@@ -2779,6 +2993,7 @@ interface(`fs_manage_nfs_dirs',`
+@@ -2779,6 +3013,7 @@ interface(`fs_manage_nfs_dirs',`
type nfs_t;
')
@@ -10337,7 +10365,7 @@ index dfe361a..f296623 100644
allow $1 nfs_t:dir manage_dir_perms;
')
-@@ -2819,6 +3034,7 @@ interface(`fs_manage_nfs_files',`
+@@ -2819,6 +3054,7 @@ interface(`fs_manage_nfs_files',`
type nfs_t;
')
@@ -10345,7 +10373,7 @@ index dfe361a..f296623 100644
manage_files_pattern($1, nfs_t, nfs_t)
')
-@@ -2845,7 +3061,7 @@ interface(`fs_dontaudit_manage_nfs_files',`
+@@ -2845,7 +3081,7 @@ interface(`fs_dontaudit_manage_nfs_files',`
#########################################
##
## Create, read, write, and delete symbolic links
@@ -10354,7 +10382,7 @@ index dfe361a..f296623 100644
##
##
##
-@@ -2859,6 +3075,7 @@ interface(`fs_manage_nfs_symlinks',`
+@@ -2859,6 +3095,7 @@ interface(`fs_manage_nfs_symlinks',`
type nfs_t;
')
@@ -10362,7 +10390,7 @@ index dfe361a..f296623 100644
manage_lnk_files_pattern($1, nfs_t, nfs_t)
')
-@@ -3989,6 +4206,42 @@ interface(`fs_dontaudit_use_tmpfs_chr_dev',`
+@@ -3989,6 +4226,42 @@ interface(`fs_dontaudit_use_tmpfs_chr_dev',`
########################################
##
@@ -10405,7 +10433,7 @@ index dfe361a..f296623 100644
## Relabel character nodes on tmpfs filesystems.
##
##
-@@ -4271,6 +4524,8 @@ interface(`fs_mount_all_fs',`
+@@ -4271,6 +4544,8 @@ interface(`fs_mount_all_fs',`
')
allow $1 filesystem_type:filesystem mount;
@@ -10414,7 +10442,7 @@ index dfe361a..f296623 100644
')
########################################
-@@ -4681,3 +4936,24 @@ interface(`fs_unconfined',`
+@@ -4681,3 +4956,24 @@ interface(`fs_unconfined',`
typeattribute $1 filesystem_unconfined_type;
')
@@ -24629,7 +24657,7 @@ index ed1af3c..40b5f0e 100644
+ delete_files_pattern($1, dkim_milter_data_t, dkim_milter_data_t)
+')
diff --git a/policy/modules/services/milter.te b/policy/modules/services/milter.te
-index 1b6dea0..f42a489 100644
+index 1b6dea0..b90c727 100644
--- a/policy/modules/services/milter.te
+++ b/policy/modules/services/milter.te
@@ -9,6 +9,13 @@ policy_module(milter, 1.2.1)
@@ -24646,7 +24674,7 @@ index 1b6dea0..f42a489 100644
# currently-supported milters are milter-greylist, milter-regex and spamass-milter
milter_template(greylist)
milter_template(regex)
-@@ -20,11 +27,27 @@ milter_template(spamass)
+@@ -20,11 +27,28 @@ milter_template(spamass)
type spamass_milter_state_t;
files_type(spamass_milter_state_t)
@@ -24656,6 +24684,7 @@ index 1b6dea0..f42a489 100644
+#
+
+allow dkim_milter_t self:capability { kill setgid setuid };
++allow dkim_milter_t self:process signal;
+allow dkim_milter_t self:unix_stream_socket create_stream_socket_perms;
+
+read_files_pattern(dkim_milter_t, dkim_milter_private_key_t, dkim_milter_private_key_t)
@@ -24676,7 +24705,7 @@ index 1b6dea0..f42a489 100644
#
# It removes any existing socket (not owned by root) whilst running as root,
-@@ -52,8 +75,8 @@ mta_read_config(greylist_milter_t)
+@@ -52,8 +76,8 @@ mta_read_config(greylist_milter_t)
########################################
#
# milter-regex local policy
@@ -24687,7 +24716,7 @@ index 1b6dea0..f42a489 100644
#
# It removes any existing socket (not owned by root) whilst running as root
-@@ -72,8 +95,8 @@ mta_read_config(regex_milter_t)
+@@ -72,8 +96,8 @@ mta_read_config(regex_milter_t)
########################################
#
# spamass-milter local policy
@@ -46507,10 +46536,10 @@ index 0000000..5f0352b
+
diff --git a/policy/modules/system/systemd.te b/policy/modules/system/systemd.te
new file mode 100644
-index 0000000..75f49c3
+index 0000000..a74c435
--- /dev/null
+++ b/policy/modules/system/systemd.te
-@@ -0,0 +1,96 @@
+@@ -0,0 +1,98 @@
+
+policy_module(systemd, 1.0.0)
+
@@ -46577,6 +46606,7 @@ index 0000000..75f49c3
+files_manage_all_pid_dirs(systemd_tmpfiles_t)
+files_manage_all_locks(systemd_tmpfiles_t)
+files_setattr_all_tmp_dirs(systemd_tmpfiles_t)
++files_unlink_all_pid_sockets(systemd_tmpfiles_t)
+
+files_purge_tmp(systemd_tmpfiles_t)
+files_manage_generic_tmp_files(systemd_tmpfiles_t)
@@ -46598,6 +46628,7 @@ index 0000000..75f49c3
+seutil_read_file_contexts(systemd_tmpfiles_t)
+
+logging_create_devlog_dev(systemd_tmpfiles_t)
++logging_send_syslog_msg(systemd_tmpfiles_t)
+
+miscfiles_delete_man_pages(systemd_tmpfiles_t)
+miscfiles_relabel_man_pages(systemd_tmpfiles_t)
diff --git a/selinux-policy.spec b/selinux-policy.spec
index 3e05f91..4b59bb1 100644
--- a/selinux-policy.spec
+++ b/selinux-policy.spec
@@ -21,7 +21,7 @@
Summary: SELinux policy configuration
Name: selinux-policy
Version: 3.9.10
-Release: 12%{?dist}
+Release: 13%{?dist}
License: GPLv2+
Group: System Environment/Base
Source: serefpolicy-%{version}.tgz
@@ -471,6 +471,11 @@ exit 0
%endif
%changelog
+* Tue Dec 14 2010 Miroslav Grepl 3.9.9-13
+- Allow sandbox to run on nfs partitions, fixes for systemd_tmpfs
+- remove per sandbox domains devpts types
+- Allow dkim-milter sending signal to itself
+
* Mon Dec 13 2010 Dan Walsh 3.9.9-12
- Allow domains that transition to ping or traceroute, kill them
- Allow user_t to conditionally transition to ping_t and traceroute_t