PERFORCE change 109980 for review
Todd Miller
millert at FreeBSD.org
Tue Nov 14 20:42:24 UTC 2006
http://perforce.freebsd.org/chv.cgi?CH=109980
Change 109980 by millert at millert_g5tower on 2006/11/14 20:35:34
Split sebsd_file_check_ioctl into sebsd_file_check_ioctl() and
sebsd_vnode_check_ioctl().
Affected files ...
.. //depot/projects/trustedbsd/sedarwin8/policies/sedarwin/sedarwin/sebsd.c#40 edit
Differences ...
==== //depot/projects/trustedbsd/sedarwin8/policies/sedarwin/sedarwin/sebsd.c#40 (text+ko) ====
@@ -3085,26 +3085,33 @@
}
#endif
+/*
+ * The file ioctl check are split into fd and vnode components.
+ */
static int
sebsd_file_check_ioctl(struct ucred *cred, struct fileglob *fg,
struct label *fglabel, u_long com, void *data)
{
struct task_security_struct *tsec;
struct file_security_struct *fsec;
- int error;
tsec = SLOT(cred->cr_label);
fsec = SLOT(fglabel);
- error = avc_has_perm(tsec->sid, fsec->sid, SECCLASS_FD,
- FD__USE, NULL);
- if (error)
- return (error);
- if (fg->fg_type != DTYPE_VNODE)
- return (0);
+ return (avc_has_perm(tsec->sid, fsec->sid, SECCLASS_FD, FD__USE, NULL));
+}
+
+static int
+sebsd_vnode_check_ioctl(struct ucred *cred, struct vnode *vp,
+ struct label *label, int com, caddr_t data)
+{
+ struct task_security_struct *tsec;
+ struct vnode_security_struct *vsec;
+
+ tsec = SLOT(cred->cr_label);
+ vsec = SLOT(label);
- return (vnode_has_perm(cred, (struct vnode *)fg->fg_data,
- NULL, FILE__IOCTL));
+ return (vnode_has_perm(cred, vp, NULL, FILE__IOCTL));
}
/*
@@ -3709,6 +3716,7 @@
// .mpo_vnode_check_kqfilter = sebsd_vnode_check_kqfilter,
.mpo_vnode_check_link = sebsd_vnode_check_link,
.mpo_vnode_check_lookup = sebsd_vnode_check_lookup,
+ .mpo_vnode_check_ioctl = sebsd_vnode_check_ioctl,
.mpo_vnode_check_open = sebsd_vnode_check_open,
.mpo_vnode_check_read = sebsd_vnode_check_read,
.mpo_vnode_check_readdir = sebsd_vnode_check_readdir,
More information about the p4-projects
mailing list