PERFORCE change 33900 for review
Robert Watson
rwatson at FreeBSD.org
Mon Jun 30 13:24:05 PDT 2003
http://perforce.freebsd.org/chv.cgi?CH=33900
Change 33900 by rwatson at rwatson_powerbook on 2003/06/30 13:23:24
#define MA_OWNED and PROC_LOCK_ASSERT to allow our lock assertions
to compile; this way we can keep them in the code minimizing diffs
and documenting potential locking require when/if Darwin locking
matures.
Define M_MACPIPELABEL and M_MACTEMP in the centralized BSD malloc
types.
Use current_proc() in preference to curproc.
Define VADMIN.
Affected files ...
.. //depot/projects/trustedbsd/sedarwin/apsl/xnu/bsd/kern/kern_mac.c#12 edit
.. //depot/projects/trustedbsd/sedarwin/apsl/xnu/bsd/sys/malloc.h#3 edit
.. //depot/projects/trustedbsd/sedarwin/apsl/xnu/bsd/sys/vnode.h#3 edit
Differences ...
==== //depot/projects/trustedbsd/sedarwin/apsl/xnu/bsd/kern/kern_mac.c#12 (text+ko) ====
@@ -87,6 +87,8 @@
#define TUNABLE_INT(x, y)
#define WITNESS_WARN(x, y, z, ...)
#define mtx_assert(x, y)
+#define MA_OWNED
+#define PROC_LOCK_ASSERT(x, y)
SYSCTL_DECL(_security);
@@ -239,9 +241,6 @@
static int mac_setlabel_vnode_extattr(struct ucred *cred,
struct vnode *vp, struct label *intlabel);
-MALLOC_DEFINE(M_MACPIPELABEL, "macpipelabel", "MAC labels for pipes");
-MALLOC_DEFINE(M_MACTEMP, "mactemp", "MAC temporary label storage");
-
/*
* mac_static_policy_list holds a list of policy modules that are not
* loaded while the system is "live", and cannot be unloaded. These
@@ -1459,7 +1458,7 @@
ASSERT_VOP_LOCKED(dvp, "mac_create_vnode_extattr");
ASSERT_VOP_LOCKED(vp, "mac_create_vnode_extattr");
- error = VOP_OPENEXTATTR(vp, cred, curproc);
+ error = VOP_OPENEXTATTR(vp, cred, current_proc());
if (error == EOPNOTSUPP) {
/* XXX: Optionally abort if transactions not supported. */
if (ea_warn_once == 0) {
@@ -1474,11 +1473,11 @@
dvp, &dvp->v_label, vp, &vp->v_label, cnp);
if (error) {
- VOP_CLOSEEXTATTR(vp, 0, NOCRED, curproc);
+ VOP_CLOSEEXTATTR(vp, 0, NOCRED, current_proc());
return (error);
}
- error = VOP_CLOSEEXTATTR(vp, 1, NOCRED, curproc);
+ error = VOP_CLOSEEXTATTR(vp, 1, NOCRED, current_proc());
if (error == EOPNOTSUPP)
error = 0; /* XXX */
@@ -1494,7 +1493,7 @@
ASSERT_VOP_LOCKED(vp, "mac_setlabel_vnode_extattr");
- error = VOP_OPENEXTATTR(vp, cred, curproc);
+ error = VOP_OPENEXTATTR(vp, cred, current_proc());
if (error == EOPNOTSUPP) {
/* XXX: Optionally abort if transactions not supported. */
if (ea_warn_once == 0) {
@@ -1508,11 +1507,11 @@
MAC_CHECK(setlabel_vnode_extattr, cred, vp, &vp->v_label, intlabel);
if (error) {
- VOP_CLOSEEXTATTR(vp, 0, NOCRED, curproc);
+ VOP_CLOSEEXTATTR(vp, 0, NOCRED, current_proc());
return (error);
}
- error = VOP_CLOSEEXTATTR(vp, 1, NOCRED, curproc);
+ error = VOP_CLOSEEXTATTR(vp, 1, NOCRED, current_proc());
if (error == EOPNOTSUPP)
error = 0; /* XXX */
@@ -3365,11 +3364,11 @@
* assume VOP_SETLABEL() will do it, because we might implement
* that as part of vop_stdsetlabel_ea().
*/
- error = VOP_ACCESS(vp, VADMIN, cred, curproc);
+ error = VOP_ACCESS(vp, VADMIN, cred, current_proc());
if (error)
return (error);
- error = VOP_SETLABEL(vp, intlabel, cred, curproc);
+ error = VOP_SETLABEL(vp, intlabel, cred, current_proc());
if (error)
return (error);
==== //depot/projects/trustedbsd/sedarwin/apsl/xnu/bsd/sys/malloc.h#3 (text+ko) ====
@@ -167,8 +167,10 @@
#define M_IGMP 90
#define M_JNL_JNL 91 /* Journaling: "struct journal" */
#define M_JNL_TR 92 /* Journaling: "struct transaction" */
+#define M_MACPIPELABEL 93
+#define M_MACTEMP 94
-#define M_LAST 93 /* Must be last type + 1 */
+#define M_LAST 95 /* Must be last type + 1 */
/* Strings corresponding to types of memory */
/* Must be in synch with the #defines above */
@@ -265,7 +267,9 @@
"TCP Segment Q",/* 89 M_TSEGQ */\
"IGMP state", /* 90 M_IGMP */\
"Journal", /* 91 M_JNL_JNL */\
- "Transaction" /* 92 M_JNL_TR */\
+ "Transaction", /* 92 M_JNL_TR */\
+ "macpipelabel", /* 93 M_MACPIPELABEL */\
+ "mactemp", /* 94 M_MACTEMP */\
}
struct kmemstats {
==== //depot/projects/trustedbsd/sedarwin/apsl/xnu/bsd/sys/vnode.h#3 (text+ko) ====
@@ -248,6 +248,7 @@
/*
* Modes. Some values same as Ixxx entries from inode.h for now.
*/
+#define VADMIN 10000 /* permission to administer */
#define VSUID 04000 /* set user id on execution */
#define VSGID 02000 /* set group id on execution */
#define VSVTX 01000 /* save swapped text even after use */
More information about the p4-projects
mailing list