diff --git a/Changelog b/Changelog
index cbb71cf9..3c16854c 100644
--- a/Changelog
+++ b/Changelog
@@ -1,3 +1,4 @@
+- Added devtmpfs support.
- Dbadm updates from KaiGai Kohei.
- Virtio disk file context update from Mika Pfluger.
- Increase bindreservport range to 512-1024 in corenetwork, from Dan Walsh.
diff --git a/policy/modules/admin/readahead.te b/policy/modules/admin/readahead.te
index 947df2b0..c1aaa794 100644
--- a/policy/modules/admin/readahead.te
+++ b/policy/modules/admin/readahead.te
@@ -1,4 +1,4 @@
-policy_module(readahead, 1.11.0)
+policy_module(readahead, 1.11.1)
########################################
#
@@ -45,6 +45,8 @@ dev_getattr_all_blk_files(readahead_t)
dev_dontaudit_read_all_blk_files(readahead_t)
dev_dontaudit_getattr_memory_dev(readahead_t)
dev_dontaudit_getattr_nvram_dev(readahead_t)
+# Early devtmpfs, before udev relabel
+dev_dontaudit_rw_generic_chr_files(readahead_t)
domain_use_interactive_fds(readahead_t)
domain_read_all_domains_state(readahead_t)
diff --git a/policy/modules/kernel/corecommands.te b/policy/modules/kernel/corecommands.te
index 5e99b332..e1963ddf 100644
--- a/policy/modules/kernel/corecommands.te
+++ b/policy/modules/kernel/corecommands.te
@@ -1,4 +1,4 @@
-policy_module(corecommands, 1.13.1)
+policy_module(corecommands, 1.13.2)
########################################
#
@@ -15,6 +15,7 @@ attribute exec_type;
#
type bin_t alias { ls_exec_t sbin_t };
corecmd_executable_file(bin_t)
+dev_associate(bin_t) #For /dev/MAKEDEV
#
# shell_exec_t is the type of user shells such as /bin/bash.
diff --git a/policy/modules/kernel/devices.if b/policy/modules/kernel/devices.if
index d0aaa1cd..e896bf75 100644
--- a/policy/modules/kernel/devices.if
+++ b/policy/modules/kernel/devices.if
@@ -71,6 +71,43 @@ interface(`dev_node',`
typeattribute $1 device_node;
')
+########################################
+##
+## Associate the specified file type with device filesystem.
+##
+##
+##
+## The type of the file to be associated.
+##
+##
+#
+interface(`dev_associate',`
+ gen_require(`
+ type device_t;
+ ')
+
+ allow $1 device_t:filesystem associate;
+ fs_associate_tmpfs($1) #For backwards compatibility
+')
+
+########################################
+##
+## Mount a filesystem on /dev
+##
+##
+##
+## Domain allow access.
+##
+##
+#
+interface(`dev_mounton',`
+ gen_require(`
+ type device_t;
+ ')
+
+ allow $1 device_t:dir mounton;
+')
+
########################################
##
## Allow full relabeling (to and from) of all device nodes.
@@ -567,6 +604,24 @@ interface(`dev_rw_generic_blk_files',`
allow $1 device_t:blk_file rw_chr_file_perms;
')
+########################################
+##
+## Dontaudit attempts to read/write generic character device files.
+##
+##
+##
+## Domain to dontaudit access.
+##
+##
+#
+interface(`dev_dontaudit_rw_generic_chr_files',`
+ gen_require(`
+ type device_t;
+ ')
+
+ dontaudit $1 device_t:chr_file rw_chr_file_perms;
+')
+
########################################
##
## Create generic character device files.
@@ -831,7 +886,7 @@ interface(`dev_filetrans',`
filetrans_pattern($1, device_t, $2, $3)
- fs_associate_tmpfs($2)
+ dev_associate($2)
files_associate_tmp($2)
')
diff --git a/policy/modules/kernel/devices.te b/policy/modules/kernel/devices.te
index ec8eb739..20c2d34a 100644
--- a/policy/modules/kernel/devices.te
+++ b/policy/modules/kernel/devices.te
@@ -1,4 +1,4 @@
-policy_module(devices, 1.10.1)
+policy_module(devices, 1.10.2)
########################################
#
@@ -18,6 +18,8 @@ fs_associate_tmpfs(device_t)
files_type(device_t)
files_mountpoint(device_t)
files_associate_tmp(device_t)
+fs_type(device_t)
+fs_use_trans devtmpfs gen_context(system_u:object_r:device_t,s0);
#
# Type for /dev/agpgart
@@ -290,6 +292,8 @@ mls_trusted_object(zero_device_t)
# Rules for all device nodes
#
+allow device_node device_t:filesystem associate;
+
fs_associate(device_node)
fs_associate_tmpfs(device_node)
diff --git a/policy/modules/kernel/filesystem.te b/policy/modules/kernel/filesystem.te
index 3561f037..30bc8609 100644
--- a/policy/modules/kernel/filesystem.te
+++ b/policy/modules/kernel/filesystem.te
@@ -1,4 +1,4 @@
-policy_module(filesystem, 1.13.1)
+policy_module(filesystem, 1.13.2)
########################################
#
@@ -191,7 +191,6 @@ files_poly_parent(tmpfs_t)
# and label the filesystem itself with the specified context.
# This is appropriate for pseudo filesystems like devpts and tmpfs
# where we want to label objects with a derived type.
-fs_use_trans devtmpfs gen_context(system_u:object_r:tmpfs_t,s0);
fs_use_trans mqueue gen_context(system_u:object_r:tmpfs_t,s0);
fs_use_trans shm gen_context(system_u:object_r:tmpfs_t,s0);
fs_use_trans tmpfs gen_context(system_u:object_r:tmpfs_t,s0);
diff --git a/policy/modules/kernel/kernel.te b/policy/modules/kernel/kernel.te
index 90ee6dbf..806026cc 100644
--- a/policy/modules/kernel/kernel.te
+++ b/policy/modules/kernel/kernel.te
@@ -1,4 +1,4 @@
-policy_module(kernel, 1.12.1)
+policy_module(kernel, 1.12.2)
########################################
#
@@ -246,8 +246,7 @@ dev_create_generic_blk_files(kernel_t)
dev_delete_generic_blk_files(kernel_t)
dev_create_generic_chr_files(kernel_t)
dev_delete_generic_chr_files(kernel_t)
-# work around until devtmpfs has device_t type
-dev_tmpfs_filetrans_dev(kernel_t, { dir blk_file chr_file })
+dev_mounton(kernel_t)
# Mount root file system. Used when loading a policy
# from initrd, then mounting the root filesystem
diff --git a/policy/modules/system/hostname.te b/policy/modules/system/hostname.te
index f1edb157..683494c5 100644
--- a/policy/modules/system/hostname.te
+++ b/policy/modules/system/hostname.te
@@ -1,4 +1,4 @@
-policy_module(hostname, 1.6.0)
+policy_module(hostname, 1.6.1)
########################################
#
@@ -25,6 +25,8 @@ kernel_list_proc(hostname_t)
kernel_read_proc_symlinks(hostname_t)
dev_read_sysfs(hostname_t)
+# Early devtmpfs, before udev relabel
+dev_dontaudit_rw_generic_chr_files(hostname_t)
domain_dontaudit_leaks(hostname_t)
domain_use_interactive_fds(hostname_t)
diff --git a/policy/modules/system/init.te b/policy/modules/system/init.te
index a100eb6d..9f9b812a 100644
--- a/policy/modules/system/init.te
+++ b/policy/modules/system/init.te
@@ -1,4 +1,4 @@
-policy_module(init, 1.15.1)
+policy_module(init, 1.15.2)
gen_require(`
class passwd rootok;
@@ -133,7 +133,6 @@ files_pid_filetrans(init_t, init_var_run_t, file)
allow init_t initctl_t:fifo_file manage_fifo_file_perms;
dev_filetrans(init_t, initctl_t, fifo_file)
-fs_associate_tmpfs(initctl_t)
# Modify utmp.
allow init_t initrc_var_run_t:file { rw_file_perms setattr };
@@ -146,6 +145,8 @@ corecmd_exec_bin(init_t)
dev_read_sysfs(init_t)
dev_read_urand(init_t)
+# Early devtmpfs
+dev_rw_generic_chr_files(init_t)
domain_getpgid_all_domains(init_t)
domain_kill_all_domains(init_t)
@@ -402,6 +403,7 @@ dev_read_sound_mixer(initrc_t)
dev_write_sound_mixer(initrc_t)
dev_setattr_all_chr_files(initrc_t)
dev_rw_lvm_control(initrc_t)
+dev_rw_generic_chr_files(initrc_t)
dev_delete_lvm_control_dev(initrc_t)
dev_manage_generic_symlinks(initrc_t)
dev_manage_generic_files(initrc_t)
diff --git a/policy/modules/system/mount.te b/policy/modules/system/mount.te
index e36909cc..24ffd8a6 100644
--- a/policy/modules/system/mount.te
+++ b/policy/modules/system/mount.te
@@ -1,4 +1,4 @@
-policy_module(mount, 1.11.0)
+policy_module(mount, 1.11.1)
########################################
#
@@ -102,6 +102,8 @@ dev_getattr_sound_dev(mount_t)
ifdef(`hide_broken_symptoms',`
dev_rw_generic_blk_files(mount_t)
')
+# Early devtmpfs, before udev relabel
+dev_dontaudit_rw_generic_chr_files(mount_t)
domain_use_interactive_fds(mount_t)
domain_dontaudit_search_all_domains_state(mount_t)