summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--docs/log-message-tags/next-number2
-rw-r--r--server/mpm/worker/worker.c27
2 files changed, 1 insertions, 28 deletions
diff --git a/docs/log-message-tags/next-number b/docs/log-message-tags/next-number
index 8a0934b514..e7ea1abc3c 100644
--- a/docs/log-message-tags/next-number
+++ b/docs/log-message-tags/next-number
@@ -1 +1 @@
-10020
+10019
diff --git a/server/mpm/worker/worker.c b/server/mpm/worker/worker.c
index 0de0726bba..969a8196bd 100644
--- a/server/mpm/worker/worker.c
+++ b/server/mpm/worker/worker.c
@@ -678,8 +678,6 @@ static void * APR_THREAD_FUNC listener_thread(apr_thread_t *thd, void * dummy)
} /* if/else */
if (!listener_may_exit) {
- apr_thread_mutex_t *mutex;
-
if (ptrans == NULL) {
/* we can't use a recycled transaction pool this time.
* create a new transaction pool */
@@ -691,31 +689,6 @@ static void * APR_THREAD_FUNC listener_thread(apr_thread_t *thd, void * dummy)
apr_allocator_owner_set(allocator, ptrans);
}
apr_pool_tag(ptrans, "transaction");
-
- /* We need a mutex in the allocator to synchronize ptrans'
- * children creations/destructions, but this mutex ought to
- * live in ptrans itself to avoid leaks, hence it's cleared
- * in ap_push_pool(). We could recycle some pconf's mutexes
- * like we do for ptrans subpools, but that'd need another
- * synchronization mechanism, whereas creating a pthread
- * mutex (unix here!) is really as simple/fast as a static
- * PTHREAD_MUTEX_INIT assignment, so let's not bother and
- * create the mutex for each ptrans (recycled or not).
- */
- rv = apr_thread_mutex_create(&mutex,
- APR_THREAD_MUTEX_DEFAULT,
- ptrans);
- if (rv != APR_SUCCESS) {
- ap_log_error(APLOG_MARK, APLOG_CRIT, rv,
- ap_server_conf, APLOGNO(10019)
- "Failed to create transaction pool mutex");
- resource_shortage = 1;
- signal_threads(ST_GRACEFUL);
- return NULL;
- }
- apr_allocator_mutex_set(apr_pool_allocator_get(ptrans),
- mutex);
-
rv = lr->accept_func(&csd, lr, ptrans);
/* later we trash rv and rely on csd to indicate success/failure */
AP_DEBUG_ASSERT(rv == APR_SUCCESS || !csd);