summaryrefslogtreecommitdiffstats
path: root/sys/kern/kern_acct.c
diff options
context:
space:
mode:
authorrwatson <rwatson@FreeBSD.org>2006-09-17 11:00:36 +0000
committerrwatson <rwatson@FreeBSD.org>2006-09-17 11:00:36 +0000
commitcc2c7c1920696be0336489e8811f3579f8d59529 (patch)
tree51ce57cd6e5d3d5db090af4108c92da0c7aa98a9 /sys/kern/kern_acct.c
parent7bfa9047b1a827bc7e2ecab6b01077d7e5d89578 (diff)
downloadFreeBSD-src-cc2c7c1920696be0336489e8811f3579f8d59529.zip
FreeBSD-src-cc2c7c1920696be0336489e8811f3579f8d59529.tar.gz
Expore kern.acct_configured, a sysctl that reflects the configured/
unconfigured state of the kernel accounting system. This is used by the accounting privilege regression test to determine whether accounting is in use and will be disrupted by the regression test. Sponsored by: nCircle Network Security, Inc. Obtained from: TrustedBSD Project MFC after: 1 month
Diffstat (limited to 'sys/kern/kern_acct.c')
-rw-r--r--sys/kern/kern_acct.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/sys/kern/kern_acct.c b/sys/kern/kern_acct.c
index 58a566f..a005c5d 100644
--- a/sys/kern/kern_acct.c
+++ b/sys/kern/kern_acct.c
@@ -94,6 +94,7 @@ static int acct_disable(struct thread *);
* acct_sx protects against changes to the active vnode and credentials
* while accounting records are being committed to disk.
*/
+static int acct_configured;
static int acct_suspended;
static struct vnode *acct_vp;
static struct ucred *acct_cred;
@@ -146,6 +147,9 @@ SYSCTL_PROC(_kern, OID_AUTO, acct_chkfreq, CTLTYPE_INT|CTLFLAG_RW,
&acctchkfreq, 0, sysctl_acct_chkfreq, "I",
"frequency for checking the free space");
+SYSCTL_INT(_kern, OID_AUTO, acct_configured, CTLFLAG_RD, &acct_configured, 0,
+ "Accounting configured or not");
+
SYSCTL_INT(_kern, OID_AUTO, acct_suspended, CTLFLAG_RD, &acct_suspended, 0,
"Accounting suspended or not");
@@ -252,6 +256,7 @@ acct(struct thread *td, struct acct_args *uap)
(void) vn_close(acct_vp, acct_flags, acct_cred, td);
VFS_UNLOCK_GIANT(vfslocked);
crfree(acct_cred);
+ acct_configured = 0;
acct_vp = NULL;
acct_cred = NULL;
acct_flags = 0;
@@ -260,6 +265,7 @@ acct(struct thread *td, struct acct_args *uap)
return (error);
}
}
+ acct_configured = 1;
sx_xunlock(&acct_sx);
log(LOG_NOTICE, "Accounting enabled\n");
return (error);
@@ -277,6 +283,7 @@ acct_disable(struct thread *td)
sx_assert(&acct_sx, SX_XLOCKED);
error = vn_close(acct_vp, acct_flags, acct_cred, td);
crfree(acct_cred);
+ acct_configured = 0;
acct_vp = NULL;
acct_cred = NULL;
acct_flags = 0;
OpenPOWER on IntegriCloud