diff --git a/security/selinux/hooks.c b/security/selinux/hooks.c index 3745922c713298d1f786eb65bd69e7955714a979..0fe5ed8c33a0ade2df5e1adb25b2b7bafa792bd0 100644 --- a/security/selinux/hooks.c +++ b/security/selinux/hooks.c @@ -981,8 +981,11 @@ static int selinux_sb_clone_mnt_opts(const struct super_block *oldsb, BUG_ON(!(oldsbsec->flags & SE_SBINITIALIZED)); /* if fs is reusing a sb, make sure that the contexts match */ - if (newsbsec->flags & SE_SBINITIALIZED) + if (newsbsec->flags & SE_SBINITIALIZED) { + if ((kern_flags & SECURITY_LSM_NATIVE_LABELS) && !set_context) + *set_kern_flags |= SECURITY_LSM_NATIVE_LABELS; return selinux_cmp_sb_context(oldsb, newsb); + } mutex_lock(&newsbsec->lock);