diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2013-04-14 13:06:31 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2013-04-14 13:06:31 -0400 |
| commit | 935d8aabd4331f47a89c3e1daa5779d23cf244ee (patch) | |
| tree | 8fff6fba14f11a55cea7a9fd3adc2e8d418b4ee1 /kernel | |
| parent | 5b55d708335a9e3e4f61f2dadf7511502205ccd1 (diff) | |
Add file_ns_capable() helper function for open-time capability checking
Nothing is using it yet, but this will allow us to delay the open-time
checks to use time, without breaking the normal UNIX permission
semantics where permissions are determined by the opener (and the file
descriptor can then be passed to a different process, or the process can
drop capabilities).
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'kernel')
| -rw-r--r-- | kernel/capability.c | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/kernel/capability.c b/kernel/capability.c index 493d97259484..f6c2ce5701e1 100644 --- a/kernel/capability.c +++ b/kernel/capability.c | |||
| @@ -393,6 +393,30 @@ bool ns_capable(struct user_namespace *ns, int cap) | |||
| 393 | EXPORT_SYMBOL(ns_capable); | 393 | EXPORT_SYMBOL(ns_capable); |
| 394 | 394 | ||
| 395 | /** | 395 | /** |
| 396 | * file_ns_capable - Determine if the file's opener had a capability in effect | ||
| 397 | * @file: The file we want to check | ||
| 398 | * @ns: The usernamespace we want the capability in | ||
| 399 | * @cap: The capability to be tested for | ||
| 400 | * | ||
| 401 | * Return true if task that opened the file had a capability in effect | ||
| 402 | * when the file was opened. | ||
| 403 | * | ||
| 404 | * This does not set PF_SUPERPRIV because the caller may not | ||
| 405 | * actually be privileged. | ||
| 406 | */ | ||
| 407 | bool file_ns_capable(const struct file *file, struct user_namespace *ns, int cap) | ||
| 408 | { | ||
| 409 | if (WARN_ON_ONCE(!cap_valid(cap))) | ||
| 410 | return false; | ||
| 411 | |||
| 412 | if (security_capable(file->f_cred, ns, cap) == 0) | ||
| 413 | return true; | ||
| 414 | |||
| 415 | return false; | ||
| 416 | } | ||
| 417 | EXPORT_SYMBOL(file_ns_capable); | ||
| 418 | |||
| 419 | /** | ||
| 396 | * capable - Determine if the current task has a superior capability in effect | 420 | * capable - Determine if the current task has a superior capability in effect |
| 397 | * @cap: The capability to be tested for | 421 | * @cap: The capability to be tested for |
| 398 | * | 422 | * |
