From owner-freebsd-current Mon Feb 11 19:45:43 2002 Delivered-To: freebsd-current@freebsd.org Received: from newman2.bestweb.net (newman2.bestweb.net [209.94.102.67]) by hub.freebsd.org (Postfix) with ESMTP id 5533437B53A for ; Mon, 11 Feb 2002 18:18:48 -0800 (PST) Received: from okeeffe.bestweb.net (okeefe.bestweb.net [209.94.100.110]) by newman2.bestweb.net (Postfix) with ESMTP id 54C1223218 for ; Mon, 11 Feb 2002 21:17:52 -0500 (EST) Received: by okeeffe.bestweb.net (Postfix, from userid 0) id 50AFD9F393; Mon, 11 Feb 2002 21:12:36 -0500 (EST) Date: Sat, 09 Feb 2002 22:29:19 -0800 From: Julian Elischer Subject: final ucred patch To: current@freebsd.org Message-Id: <20020212021236.50AFD9F393@okeeffe.bestweb.net> Sender: owner-freebsd-current@FreeBSD.ORG Precedence: bulk List-ID: List-Archive: (Web Archive) List-Help: (List Instructions) List-Subscribe: List-Unsubscribe: X-Loop: FreeBSD.ORG This is a multi-part message in MIME format. --Boundary_(ID_TA6w1McSahPHMx8+rAaDoQ) Content-type: text/plain; charset=iso-8859-2 Content-transfer-encoding: 7BIT After comments by jhb and bde  -- +------------------------------------+ ______ _ __ | __--_|\ Julian Elischer | \ U \/ / hard at work in | / \ julian@elischer.org +------>x USA \ a very strange | ( OZ ) \___ ___ | country ! +- X_.---._/ presently in San Francisco \_/ \\ v --Boundary_(ID_TA6w1McSahPHMx8+rAaDoQ) Content-type: text/plain; charset=iso-8859-2; name=thediff Content-transfer-encoding: 7BIT Content-disposition: inline; filename=thediff ? i386/conf/LINT Index: i386/i386/trap.c =================================================================== RCS file: /home/ncvs/src/sys/i386/i386/trap.c,v retrieving revision 1.211 diff -u -r1.211 trap.c --- i386/i386/trap.c 10 Jan 2002 11:49:54 -0000 1.211 +++ i386/i386/trap.c 10 Feb 2002 00:52:58 -0000 @@ -256,9 +256,19 @@ sticks = td->td_kse->ke_sticks; td->td_frame = &frame; KASSERT(td->td_ucred == NULL, ("already have a ucred")); - PROC_LOCK(p); - td->td_ucred = crhold(p->p_ucred); - PROC_UNLOCK(p); + if (td->td_ucred != p->p_ucred) { + if (td->td_ucred) { + mtx_lock(&Giant); + crfree(td->td_ucred); + td->td_ucred = NULL; + mtx_unlock(&Giant); + } + if (p->p_ucred) { + PROC_LOCK(p); + td->td_ucred = crhold(p->p_ucred); + PROC_UNLOCK(p); + } + } switch (type) { case T_PRIVINFLT: /* privileged instruction fault */ @@ -644,10 +654,12 @@ userret(td, &frame, sticks); mtx_assert(&Giant, MA_NOTOWNED); userout: +#ifdef INVARIANTS mtx_lock(&Giant); crfree(td->td_ucred); - mtx_unlock(&Giant); td->td_ucred = NULL; + mtx_unlock(&Giant); +#endif out: return; } @@ -954,9 +966,19 @@ sticks = td->td_kse->ke_sticks; td->td_frame = &frame; KASSERT(td->td_ucred == NULL, ("already have a ucred")); - PROC_LOCK(p); - td->td_ucred = crhold(p->p_ucred); - PROC_UNLOCK(p); + if (td->td_ucred != p->p_ucred) { + if (td->td_ucred) { + mtx_lock(&Giant); + crfree(td->td_ucred); + td->td_ucred = NULL; + mtx_unlock(&Giant); + } + if (p->p_ucred) { + PROC_LOCK(p); + td->td_ucred = crhold(p->p_ucred); + PROC_UNLOCK(p); + } + } params = (caddr_t)frame.tf_esp + sizeof(int); code = frame.tf_eax; orig_tf_eflags = frame.tf_eflags; @@ -1099,10 +1121,14 @@ */ STOPEVENT(p, S_SCX, code); - mtx_lock(&Giant); - crfree(td->td_ucred); - mtx_unlock(&Giant); - td->td_ucred = NULL; +#ifdef INVARIANTS + if (td->td_ucred) { + mtx_lock(&Giant); + crfree(td->td_ucred); + td->td_ucred = NULL; + mtx_unlock(&Giant); + } +#endif #ifdef WITNESS if (witness_list(td)) { panic("system call %s returning with mutex(s) held\n", Index: kern/subr_trap.c =================================================================== RCS file: /home/ncvs/src/sys/kern/subr_trap.c,v retrieving revision 1.206 diff -u -r1.206 subr_trap.c --- kern/subr_trap.c 17 Jan 2002 17:49:23 -0000 1.206 +++ kern/subr_trap.c 10 Feb 2002 00:53:00 -0000 @@ -161,9 +161,19 @@ p->p_stats->p_prof.pr_ticks = 0; } mtx_unlock_spin(&sched_lock); - PROC_LOCK(p); - td->td_ucred = crhold(p->p_ucred); - PROC_UNLOCK(p); + if (td->td_ucred != p->p_ucred) { + if (td->td_ucred) { + mtx_lock(&Giant); + crfree(td->td_ucred); + td->td_ucred = NULL; + mtx_unlock(&Giant); + } + if (p->p_ucred) { + PROC_LOCK(p); + td->td_ucred = crhold(p->p_ucred); + PROC_UNLOCK(p); + } + } if (flags & KEF_OWEUPC && sflag & PS_PROFIL) addupc_task(ke, p->p_stats->p_prof.pr_addr, prticks); if (sflag & PS_ALRMPEND) { @@ -188,10 +198,14 @@ } userret(td, framep, sticks); - mtx_lock(&Giant); - crfree(td->td_ucred); - mtx_unlock(&Giant); - td->td_ucred = NULL; +#ifdef INVARIANTS + if (td->td_ucred) { + mtx_lock(&Giant); + crfree(td->td_ucred); + td->td_ucred = NULL; + mtx_unlock(&Giant); + } +#endif s = cpu_critical_enter(); } mtx_assert(&Giant, MA_NOTOWNED); --Boundary_(ID_TA6w1McSahPHMx8+rAaDoQ)-- To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-current" in the body of the message To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-current" in the body of the message