Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 8 Jul 2004 21:46:55 GMT
From:      Robert Watson <rwatson@FreeBSD.org>
To:        Perforce Change Reviews <perforce@freebsd.org>
Subject:   PERFORCE change 56811 for review
Message-ID:  <200407082146.i68LktDM028562@repoman.freebsd.org>

next in thread | raw e-mail | index | archive | help
http://perforce.freebsd.org/chv.cgi?CH=56811

Change 56811 by rwatson@rwatson_tislabs on 2004/07/08 21:46:17

	Remove module refcount; maybe removed a little too much and will
	have to re-add it.

Affected files ...

.. //depot/projects/trustedbsd/mac/sys/kern/sysv_shm.c#20 edit

Differences ...

==== //depot/projects/trustedbsd/mac/sys/kern/sysv_shm.c#20 (text+ko) ====

@@ -94,8 +94,6 @@
 
 static int shm_last_free, shm_nused, shm_committed, shmalloced;
 static struct shmid_kernel	*shmsegs;
-static int refcount; /* to ensure consistency during and after shmunload */
-static struct mtx refcnt_mtx;	/* global mutex for refcount. */
 
 struct shm_handle {
 	/* vm_offset_t kva; */
@@ -283,18 +281,6 @@
 	if (!jail_sysvipc_allowed && jailed(td->td_ucred))
 		return (ENOSYS);
 
-	/*
-	 * Prevent thread from going any further if module is (being)
-	 * unloaded.
-	 */
-	mtx_lock(&refcnt_mtx);
-	if (refcount < 0 ) {
-		mtx_unlock(&refcnt_mtx);
-		return (ENOSYS);
-	}
-	refcount++; /* Indicate that thread is active in the code-path */
-	mtx_unlock(&refcnt_mtx);
-
 	mtx_lock(&Giant);
 	shmmap_s = p->p_vmspace->vm_shm;
  	if (shmmap_s == NULL) {
@@ -327,9 +313,6 @@
 	error = shm_delete_mapping(p->p_vmspace, shmmap_s);
 done2:
 	mtx_unlock(&Giant);
-	mtx_lock(&refcnt_mtx);
-	refcount--; /* Indicate that thread no longer active in the code-path */
-	mtx_unlock(&refcnt_mtx);
 	return (error);
 }
 
@@ -365,18 +348,6 @@
 	if (!jail_sysvipc_allowed && jailed(td->td_ucred))
 		return (ENOSYS);
 
-	/*
-	 * Prevent thread from going any further if module is (being)
-	 * unloaded.
-	 */
-	mtx_lock(&refcnt_mtx);
-	if (refcount < 0 ) {
-		mtx_unlock(&refcnt_mtx);
-		return (ENOSYS);
-	}
-	refcount++; /* Indicate that thread is active in the code-path */
-	mtx_unlock(&refcnt_mtx);
-
 	mtx_lock(&Giant);
 	shmmap_s = p->p_vmspace->vm_shm;
 	if (shmmap_s == NULL) {
@@ -459,9 +430,6 @@
 	td->td_retval[0] = attach_va;
 done2:
 	mtx_unlock(&Giant);
-	mtx_lock(&refcnt_mtx);
-	refcount--; /* Indicate that thread no longer active in the code-path */
-	mtx_unlock(&refcnt_mtx);
 	return (error);
 }
 
@@ -507,18 +475,6 @@
 	if (!jail_sysvipc_allowed && jailed(td->td_ucred))
 		return (ENOSYS);
 
-	/*
-	 * Prevent thread from going any further if module is (being)
-	 * unloaded.
-	 */
-	mtx_lock(&refcnt_mtx);
-	if (refcount < 0 ) {
-		mtx_unlock(&refcnt_mtx);
-		return (ENOSYS);
-	}
-	refcount++; /* Indicate that thread is active in the code-path */
-	mtx_unlock(&refcnt_mtx);
-
 	mtx_lock(&Giant);
 	shmseg = shm_find_segment_by_shmid(uap->shmid);
 	if (shmseg == NULL) {
@@ -557,9 +513,6 @@
 	}
 done2:
 	mtx_unlock(&Giant);
-	mtx_lock(&refcnt_mtx);
-	refcount--; /* Indicate that thread no longer active in the code-path */
-	mtx_unlock(&refcnt_mtx);
 	return (error);
 #else
 	return (EINVAL);
@@ -591,18 +544,6 @@
 	if (!jail_sysvipc_allowed && jailed(td->td_ucred))
 		return (ENOSYS);
 
-	/*
-	 * Prevent thread from going any further if module is (being)
-	 * unloaded
-	 */
-	mtx_lock(&refcnt_mtx);
-	if (refcount < 0 ) {
-		mtx_unlock(&refcnt_mtx);
-		return (ENOSYS);
-	}
-	refcount++; /* Indicate that thread is active in the code-path */
-	mtx_unlock(&refcnt_mtx);
-
 	mtx_lock(&Giant);
 	switch (cmd) {
 	case IPC_INFO:
@@ -689,9 +630,6 @@
 	}
 done2:
 	mtx_unlock(&Giant);
-	mtx_lock(&refcnt_mtx);
-	refcount--; /* Indicate that thread no longer active in the code-path */
-	mtx_unlock(&refcnt_mtx);
 	return (error);
 }
 
@@ -882,18 +820,6 @@
 	if (!jail_sysvipc_allowed && jailed(td->td_ucred))
 		return (ENOSYS);
 
-	/*
-	 * Prevent thread from going any further if module is (being)
-	 * unloaded.
-	 */
-	mtx_lock(&refcnt_mtx);
-	if (refcount < 0 ) {
-		mtx_unlock(&refcnt_mtx);
-		return (ENOSYS);
-	}
-	refcount++; /* Indicate that thread is active in the code-path */
-	mtx_unlock(&refcnt_mtx);
-
 	mtx_lock(&Giant);
 	mode = uap->shmflg & ACCESSPERMS;
 	if (uap->key != IPC_PRIVATE) {
@@ -913,9 +839,6 @@
 	error = shmget_allocate_segment(td, uap, mode);
 done2:
 	mtx_unlock(&Giant);
-	mtx_lock(&refcnt_mtx);
-	refcount--; /* Indicate that thread no longer active in the code-path */
-	mtx_unlock(&refcnt_mtx);
 	return (error);
 }
 
@@ -1043,39 +966,14 @@
 	shm_committed = 0;
 	shmexit_hook = &shmexit_myhook;
 	shmfork_hook = &shmfork_myhook;
-	refcount = 0;
-	/*
-	 * It is not permissible to pass the same mutex to mtx_init()
-	 * multiple times without intervening calls to mtx_destroy().  Since
-	 * we cannot destroy the refcnt_mtx during shmunload, we check if
-	 * the mtx_init has ever been called. If so, we dont need to do
-	 * mtx_init as the mutex is already initialized.
-	 */
-	if (mtx_initialized(&refcnt_mtx) == 0)
-		mtx_init(&refcnt_mtx, "shmrefcnt", NULL, MTX_DEF);
 }
 
 static int
 shmunload()
 {
-
-	/*
-	 * Make sure that the shmunload maintains the consistency of the
-	 * shmsegs data structure.  This assures that the unload doesn't
-	 * take place if any thread is in any of the code-paths (tinkering
-	 * with the data structures), and also that no thread can enter
-	 * the code-paths once the module is unloaded.
-	 */
-	mtx_lock(&refcnt_mtx);
-	if ((refcount > 0) || (shm_nused > 0)) {
-		mtx_unlock(&refcnt_mtx);
-		return (EBUSY);
-	}
-	refcount= -1; /* Mark the module as being unloaded */
-	mtx_unlock(&refcnt_mtx);
-
 #ifdef MAC
 	int i;	
+
 	for (i = 0; i < shmalloced; i++)
   	mac_destroy_ipc_shm(&shmsegs[i]);
 #endif



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200407082146.i68LktDM028562>