summaryrefslogtreecommitdiff
path: root/platform.c
diff options
context:
space:
mode:
authorDarren Tucker <dtucker@zip.com.au>2016-06-14 10:48:27 +1000
committerDarren Tucker <dtucker@zip.com.au>2016-06-14 10:48:27 +1000
commita86ec4d0737ac5879223e7cd9d68c448df46e169 (patch)
tree3c19c64dcef03b459e5bae0c03e968791c65283d /platform.c
parent0f916d39b039fdc0b5baf9b5ab0754c0f11ec573 (diff)
Use Solaris setpflags(__PROC_PROTECT, ...).
Where possible, use Solaris setpflags to disable process tracing on ssh-agent and sftp-server. bz#2584, based on a patch from huieying.lee at oracle.com, ok djm.
Diffstat (limited to 'platform.c')
-rw-r--r--platform.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/platform.c b/platform.c
index e3722e4ae..c68bb09c1 100644
--- a/platform.c
+++ b/platform.c
@@ -22,6 +22,9 @@
22#if defined(HAVE_SYS_PRCTL_H) 22#if defined(HAVE_SYS_PRCTL_H)
23#include <sys/prctl.h> /* For prctl() and PR_SET_DUMPABLE */ 23#include <sys/prctl.h> /* For prctl() and PR_SET_DUMPABLE */
24#endif 24#endif
25#ifdef HAVE_PRIV_H
26#include <priv.h> /* For setpflags() and __PROC_PROTECT */
27#endif
25 28
26#include <stdarg.h> 29#include <stdarg.h>
27#include <unistd.h> 30#include <unistd.h>
@@ -229,4 +232,9 @@ platform_disable_tracing(int strict)
229 if (prctl(PR_SET_DUMPABLE, 0) != 0 && strict) 232 if (prctl(PR_SET_DUMPABLE, 0) != 0 && strict)
230 fatal("unable to make the process undumpable"); 233 fatal("unable to make the process undumpable");
231#endif 234#endif
235#if defined(HAVE_SETPFLAGS) && defined(__PROC_PROTECT)
236 /* On Solaris, we should make this process untraceable */
237 if (setpflags(__PROC_PROTECT, 1) != 0 && strict)
238 fatal("unable to make the process untraceable");
239#endif
232} 240}