diff options
author | Al Viro <viro@zeniv.linux.org.uk> | 2009-03-30 05:45:36 -0400 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2009-03-31 23:00:25 -0400 |
commit | 11d06b2a1e5658f448a308aa3beb97bacd64a940 (patch) | |
tree | 5e6fdad704151ac54eb60a5ea5de7a6e5f79112e | |
parent | 15f7176eb1cccec0a332541285ee752b935c1c85 (diff) |
Kill unsharing fs_struct in __set_personality()
That's a rudiment of altroot support. I.e. it should've been buried
a long time ago.
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
-rw-r--r-- | kernel/exec_domain.c | 22 |
1 files changed, 0 insertions, 22 deletions
diff --git a/kernel/exec_domain.c b/kernel/exec_domain.c index 667c841c2952..cb8e9626c215 100644 --- a/kernel/exec_domain.c +++ b/kernel/exec_domain.c | |||
@@ -145,28 +145,6 @@ __set_personality(u_long personality) | |||
145 | return 0; | 145 | return 0; |
146 | } | 146 | } |
147 | 147 | ||
148 | if (atomic_read(¤t->fs->count) != 1) { | ||
149 | struct fs_struct *fsp, *ofsp; | ||
150 | |||
151 | fsp = copy_fs_struct(current->fs); | ||
152 | if (fsp == NULL) { | ||
153 | module_put(ep->module); | ||
154 | return -ENOMEM; | ||
155 | } | ||
156 | |||
157 | task_lock(current); | ||
158 | ofsp = current->fs; | ||
159 | current->fs = fsp; | ||
160 | task_unlock(current); | ||
161 | |||
162 | put_fs_struct(ofsp); | ||
163 | } | ||
164 | |||
165 | /* | ||
166 | * At that point we are guaranteed to be the sole owner of | ||
167 | * current->fs. | ||
168 | */ | ||
169 | |||
170 | current->personality = personality; | 148 | current->personality = personality; |
171 | oep = current_thread_info()->exec_domain; | 149 | oep = current_thread_info()->exec_domain; |
172 | current_thread_info()->exec_domain = ep; | 150 | current_thread_info()->exec_domain = ep; |