Commit e819ff51 authored by John Johansen's avatar John Johansen Committed by James Morris

AppArmor: Drop hack to remove appended " (deleted)" string

The 2.6.36 kernel has refactored __d_path() so that it no longer appends
" (deleted)" to unlinked paths.  So drop the hack that was used to detect
and remove the appended string.
Signed-off-by: default avatarJohn Johansen <john.johansen@canonical.com>
Signed-off-by: default avatarJames Morris <jmorris@namei.org>
parent 98e52c37
...@@ -59,8 +59,7 @@ static int d_namespace_path(struct path *path, char *buf, int buflen, ...@@ -59,8 +59,7 @@ static int d_namespace_path(struct path *path, char *buf, int buflen,
{ {
struct path root, tmp; struct path root, tmp;
char *res; char *res;
int deleted, connected; int connected, error = 0;
int error = 0;
/* Get the root we want to resolve too, released below */ /* Get the root we want to resolve too, released below */
if (flags & PATH_CHROOT_REL) { if (flags & PATH_CHROOT_REL) {
...@@ -74,19 +73,8 @@ static int d_namespace_path(struct path *path, char *buf, int buflen, ...@@ -74,19 +73,8 @@ static int d_namespace_path(struct path *path, char *buf, int buflen,
} }
spin_lock(&dcache_lock); spin_lock(&dcache_lock);
/* There is a race window between path lookup here and the
* need to strip the " (deleted) string that __d_path applies
* Detect the race and relookup the path
*
* The stripping of (deleted) is a hack that could be removed
* with an updated __d_path
*/
do {
tmp = root; tmp = root;
deleted = d_unlinked(path->dentry);
res = __d_path(path, &tmp, buf, buflen); res = __d_path(path, &tmp, buf, buflen);
} while (deleted != d_unlinked(path->dentry));
spin_unlock(&dcache_lock); spin_unlock(&dcache_lock);
*name = res; *name = res;
...@@ -98,22 +86,18 @@ static int d_namespace_path(struct path *path, char *buf, int buflen, ...@@ -98,22 +86,18 @@ static int d_namespace_path(struct path *path, char *buf, int buflen,
*name = buf; *name = buf;
goto out; goto out;
} }
if (deleted) {
/* On some filesystems, newly allocated dentries appear to the
* security_path hooks as a deleted dentry except without an
* inode allocated.
*
* Remove the appended deleted text and return as string for
* normal mediation, or auditing. The (deleted) string is
* guaranteed to be added in this case, so just strip it.
*/
buf[buflen - 11] = 0; /* - (len(" (deleted)") +\0) */
if (path->dentry->d_inode && !(flags & PATH_MEDIATE_DELETED)) { /* Handle two cases:
* 1. A deleted dentry && profile is not allowing mediation of deleted
* 2. On some filesystems, newly allocated dentries appear to the
* security_path hooks as a deleted dentry except without an inode
* allocated.
*/
if (d_unlinked(path->dentry) && path->dentry->d_inode &&
!(flags & PATH_MEDIATE_DELETED)) {
error = -ENOENT; error = -ENOENT;
goto out; goto out;
} }
}
/* Determine if the path is connected to the expected root */ /* Determine if the path is connected to the expected root */
connected = tmp.dentry == root.dentry && tmp.mnt == root.mnt; connected = tmp.dentry == root.dentry && tmp.mnt == root.mnt;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment