summaryrefslogtreecommitdiffstats
path: root/os/unix/unixd.c
diff options
context:
space:
mode:
authorJim Jagielski <jim@apache.org>2009-03-30 18:10:26 +0200
committerJim Jagielski <jim@apache.org>2009-03-30 18:10:26 +0200
commit0464e456f6de7e9cd9f13cea22f874247a6525c9 (patch)
tree4ca15735444f7a6379e6a3384db77525995f293d /os/unix/unixd.c
parentClarify when CoreDumpDirectory can be moot based on OS configuration, and (diff)
downloadapache2-0464e456f6de7e9cd9f13cea22f874247a6525c9.tar.xz
apache2-0464e456f6de7e9cd9f13cea22f874247a6525c9.zip
revert 759711 and 759713... don't require apr2
git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@760026 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'os/unix/unixd.c')
-rw-r--r--os/unix/unixd.c69
1 files changed, 60 insertions, 9 deletions
diff --git a/os/unix/unixd.c b/os/unix/unixd.c
index 1aaac20f67..1eb43732a0 100644
--- a/os/unix/unixd.c
+++ b/os/unix/unixd.c
@@ -26,7 +26,6 @@
#include "apr_thread_proc.h"
#include "apr_strings.h"
#include "apr_portable.h"
-#include "apr_perms_set.h"
#ifdef HAVE_PWD_H
#include <pwd.h>
#endif
@@ -209,19 +208,71 @@ AP_DECLARE(apr_status_t) ap_os_create_privileged_process(
attr, ugid, p);
}
+/* XXX move to APR and externalize (but implement differently :) ) */
+static apr_lockmech_e proc_mutex_mech(apr_proc_mutex_t *pmutex)
+{
+ const char *mechname = apr_proc_mutex_name(pmutex);
+
+ if (!strcmp(mechname, "sysvsem")) {
+ return APR_LOCK_SYSVSEM;
+ }
+ else if (!strcmp(mechname, "flock")) {
+ return APR_LOCK_FLOCK;
+ }
+ return APR_LOCK_DEFAULT;
+}
+
AP_DECLARE(apr_status_t) ap_unixd_set_proc_mutex_perms(apr_proc_mutex_t *pmutex)
{
- apr_status_t rv = APR_SUCCESS;
if (!geteuid()) {
- rv = APR_PERMS_SET_FN(proc_mutex)(pmutex,
- APR_FPROT_UWRITE | APR_FPROT_UREAD,
- ap_unixd_config.user_id,
- ap_unixd_config.group_id);
- if (rv == APR_ENOTIMPL) {
- rv = APR_SUCCESS;
+ apr_lockmech_e mech = proc_mutex_mech(pmutex);
+
+ switch(mech) {
+#if APR_HAS_SYSVSEM_SERIALIZE
+ case APR_LOCK_SYSVSEM:
+ {
+ apr_os_proc_mutex_t ospmutex;
+#if !APR_HAVE_UNION_SEMUN
+ union semun {
+ long val;
+ struct semid_ds *buf;
+ unsigned short *array;
+ };
+#endif
+ union semun ick;
+ struct semid_ds buf;
+
+ apr_os_proc_mutex_get(&ospmutex, pmutex);
+ buf.sem_perm.uid = ap_unixd_config.user_id;
+ buf.sem_perm.gid = ap_unixd_config.group_id;
+ buf.sem_perm.mode = 0600;
+ ick.buf = &buf;
+ if (semctl(ospmutex.crossproc, 0, IPC_SET, ick) < 0) {
+ return errno;
+ }
+ }
+ break;
+#endif
+#if APR_HAS_FLOCK_SERIALIZE
+ case APR_LOCK_FLOCK:
+ {
+ const char *lockfile = apr_proc_mutex_lockfile(pmutex);
+
+ if (lockfile) {
+ if (chown(lockfile, ap_unixd_config.user_id,
+ -1 /* no gid change */) < 0) {
+ return errno;
+ }
+ }
+ }
+ break;
+#endif
+ default:
+ /* do nothing */
+ break;
}
}
- return rv;
+ return APR_SUCCESS;
}
AP_DECLARE(apr_status_t) ap_unixd_set_global_mutex_perms(apr_global_mutex_t *gmutex)