Port: Implement prctl wrapper
authorJérémie Galarneau <jeremie.galarneau@efficios.com>
Sat, 17 Oct 2015 23:34:03 +0000 (19:34 -0400)
committerJérémie Galarneau <jeremie.galarneau@efficios.com>
Mon, 19 Oct 2015 18:54:21 +0000 (14:54 -0400)
Signed-off-by: Jérémie Galarneau <jeremie.galarneau@efficios.com>
src/common/compat/Makefile.am
src/common/compat/prctl.h [new file with mode: 0644]
src/common/runas.c

index 9b1211701128bbc8335588e4ed9200a9bdc1fec4..e12422585d529d8ae90de9795ff8154fba85c3e6 100644 (file)
@@ -10,4 +10,4 @@ endif
 
 libcompat_la_SOURCES = poll.h fcntl.h endian.h mman.h \
                socket.h compat-fcntl.c uuid.h tid.h \
 
 libcompat_la_SOURCES = poll.h fcntl.h endian.h mman.h \
                socket.h compat-fcntl.c uuid.h tid.h \
-               getenv.h string.h $(COMPAT)
+               getenv.h string.h prctl.h $(COMPAT)
diff --git a/src/common/compat/prctl.h b/src/common/compat/prctl.h
new file mode 100644 (file)
index 0000000..39e7ec7
--- /dev/null
@@ -0,0 +1,46 @@
+/*
+ * Copyright (C) 2015 - Jérémie Galarneau <jeremie.galarneau@efficios.com>
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License, version 2 only,
+ * as published by the Free Software Foundation.
+ *
+ * This program is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
+ * more details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with this program; if not, write to the Free Software Foundation, Inc.,
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+ */
+
+#ifndef _COMPAT_PRCTL_H
+#define _COMPAT_PRCTL_H
+
+#ifdef __linux__
+#include <sys/prctl.h>
+
+static inline
+int lttng_prctl(int option, unsigned long arg2, unsigned long arg3,
+               unsigned long arg4, unsigned long arg5)
+{
+       return prctl(option, arg2, arg3, arg4, arg5);
+}
+
+#else
+
+#ifndef PR_SET_NAME
+#define PR_SET_NAME 0
+#endif /* PR_SET_NAME */
+
+static inline
+int lttng_prctl(int option, unsigned long arg2, unsigned long arg3,
+               unsigned long arg4, unsigned long arg5)
+{
+       return -ENOSYS;
+}
+
+#endif /* __linux__ */
+
+#endif /* _COMPAT_PRCTL_H */
index bc7356b6a6641b9d28a83d1171081a1d0b2ab7d9..7e5743be1c4656005dccd8036c586f76f492a00b 100644 (file)
 #include <sched.h>
 #include <sys/signal.h>
 #include <assert.h>
 #include <sched.h>
 #include <sys/signal.h>
 #include <assert.h>
-#include <sys/prctl.h>
+#include <signal.h>
 
 #include <common/common.h>
 #include <common/utils.h>
 #include <common/compat/getenv.h>
 
 #include <common/common.h>
 #include <common/utils.h>
 #include <common/compat/getenv.h>
+#include <common/compat/prctl.h>
 #include <common/sessiond-comm/unix.h>
 
 #include "runas.h"
 #include <common/sessiond-comm/unix.h>
 
 #include "runas.h"
@@ -323,8 +324,9 @@ int run_as_worker(struct run_as_worker *worker)
        memset(worker->procname, 0, proc_orig_len);
        strncpy(worker->procname, DEFAULT_RUN_AS_WORKER_NAME, proc_orig_len);
 
        memset(worker->procname, 0, proc_orig_len);
        strncpy(worker->procname, DEFAULT_RUN_AS_WORKER_NAME, proc_orig_len);
 
-       ret = prctl(PR_SET_NAME, DEFAULT_RUN_AS_WORKER_NAME, 0, 0, 0);
-       if (ret) {
+       ret = lttng_prctl(PR_SET_NAME,
+                       (unsigned long) DEFAULT_RUN_AS_WORKER_NAME, 0, 0, 0);
+       if (ret && ret != -ENOSYS) {
                /* Don't fail as this is not essential. */
                PERROR("prctl PR_SET_NAME");
                ret = 0;
                /* Don't fail as this is not essential. */
                PERROR("prctl PR_SET_NAME");
                ret = 0;
This page took 0.027037 seconds and 4 git commands to generate.