summaryrefslogtreecommitdiffstats
path: root/sys/compat/linux/linux_misc.c
diff options
context:
space:
mode:
authorrwatson <rwatson@FreeBSD.org>2002-08-01 22:23:02 +0000
committerrwatson <rwatson@FreeBSD.org>2002-08-01 22:23:02 +0000
commitb246ee0a3cced8c39f5aaa8505242e775d93e8c4 (patch)
tree1b32476766408c94dcee10b7fe67f140d5da3e23 /sys/compat/linux/linux_misc.c
parent41f4dc56d14bda3dbbebfdb61740397a2caf7321 (diff)
downloadFreeBSD-src-b246ee0a3cced8c39f5aaa8505242e775d93e8c4.zip
FreeBSD-src-b246ee0a3cced8c39f5aaa8505242e775d93e8c4.tar.gz
Introduce support for Mandatory Access Control and extensible
kernel access control. Invoke appropriate MAC entry points for a number of VFS-related operations in the Linux ABI module. In particular, handle uselib in a manner similar to open() (more work is probably needed here), as well as handle statfs(), and linux readdir()-like calls. Obtained from: TrustedBSD Project Sponsored by: DARPA, NAI Labs
Diffstat (limited to 'sys/compat/linux/linux_misc.c')
-rw-r--r--sys/compat/linux/linux_misc.c9
1 files changed, 8 insertions, 1 deletions
diff --git a/sys/compat/linux/linux_misc.c b/sys/compat/linux/linux_misc.c
index c081fc1..7eebf69 100644
--- a/sys/compat/linux/linux_misc.c
+++ b/sys/compat/linux/linux_misc.c
@@ -29,6 +29,7 @@
*/
#include "opt_compat.h"
+#include "opt_mac.h"
#include <sys/param.h>
#include <sys/systm.h>
@@ -37,6 +38,7 @@
#include <sys/jail.h>
#include <sys/kernel.h>
#include <sys/lock.h>
+#include <sys/mac.h>
#include <sys/mman.h>
#include <sys/mount.h>
#include <sys/mutex.h>
@@ -250,7 +252,7 @@ linux_uselib(struct thread *td, struct linux_uselib_args *args)
vp = NULL;
/*
- * XXX This code should make use of vn_open(), rather than doing
+ * XXX: This code should make use of vn_open(), rather than doing
* all this stuff itself.
*/
NDINIT(&ni, LOOKUP, FOLLOW|LOCKLEAF, UIO_USERSPACE, args->library, td);
@@ -306,6 +308,11 @@ linux_uselib(struct thread *td, struct linux_uselib_args *args)
* XXX: This should use vn_open() so that it is properly authorized,
* and to reduce code redundancy all over the place here.
*/
+#ifdef MAC
+ error = mac_check_vnode_open(td->td_ucred, vp, FREAD);
+ if (error)
+ goto cleanup;
+#endif
error = VOP_OPEN(vp, FREAD, td->td_ucred, td);
if (error)
goto cleanup;
OpenPOWER on IntegriCloud