aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBaptiste Daroussin <bapt@FreeBSD.org>2016-09-18 18:49:18 +0000
committerBaptiste Daroussin <bapt@FreeBSD.org>2016-09-18 18:49:18 +0000
commit8197e93d397319539276a51784679a07eb360261 (patch)
tree11d0e4d5bbbb9cbb687efc75bf46072054663bc5
parent2fb709ef75b0679ed65f868d2b115462bda61628 (diff)
Fix building as bootstrap tools on pre-capsicum.h systems
Notes
Notes: svn path=/head/; revision=305948
-rw-r--r--usr.bin/soelim/soelim.c15
1 files changed, 11 insertions, 4 deletions
diff --git a/usr.bin/soelim/soelim.c b/usr.bin/soelim/soelim.c
index c9ac69c5329e..787e42033126 100644
--- a/usr.bin/soelim/soelim.c
+++ b/usr.bin/soelim/soelim.c
@@ -27,7 +27,10 @@
#include <sys/cdefs.h>
__FBSDID("$FreeBSD$");
+#include <sys/param.h>
+#if __FreeBSD_version > 1001510
#include <sys/capsicum.h>
+#endif
#include <sys/types.h>
#include <ctype.h>
@@ -159,9 +162,11 @@ main(int argc, char **argv)
int ch, i, rootfd;
int ret = 0;
int flags = 0;
- unsigned long cmd;
char cwd[MAXPATHLEN];
+#if __FreeBSD_version > 1001510
+ unsigned long cmd;
cap_rights_t rights;
+#endif
includes = sl_init();
if (getcwd(cwd, sizeof(cwd)) != NULL)
@@ -192,6 +197,10 @@ main(int argc, char **argv)
argc -= optind;
argv += optind;
+ rootfd = open("/", O_DIRECTORY | O_RDONLY);
+ if (rootfd == -1)
+ err(EXIT_FAILURE, "unable to open '/'");
+#if __FreeBSD_version > 1001510
cap_rights_init(&rights, CAP_READ, CAP_FSTAT, CAP_IOCTL);
/*
* EBADF in case stdin is closed by the caller
@@ -204,9 +213,6 @@ main(int argc, char **argv)
err(EXIT_FAILURE, "unable to limit rights for stdout");
if (cap_rights_limit(STDERR_FILENO, &rights) < 0 && errno != ENOSYS)
err(EXIT_FAILURE, "unable to limit rights for stderr");
- rootfd = open("/", O_DIRECTORY | O_RDONLY);
- if (rootfd == -1)
- err(EXIT_FAILURE, "unable to open '/'");
cap_rights_init(&rights, CAP_READ, CAP_LOOKUP, CAP_FSTAT, CAP_FCNTL);
if (cap_rights_limit(rootfd, &rights) < 0 && errno != ENOSYS)
err(EXIT_FAILURE, "unable to limit rights");
@@ -221,6 +227,7 @@ main(int argc, char **argv)
if (cap_enter() < 0 && errno != ENOSYS)
err(EXIT_FAILURE, "unable to enter capability mode");
+#endif
if (argc == 0)
ret = soelim_file(rootfd, stdin, flags);