summaryrefslogtreecommitdiff
path: root/release/src/router/busybox/coreutils/libcoreutils/getopt_mk_fifo_nod.c
diff options
context:
space:
mode:
Diffstat (limited to 'release/src/router/busybox/coreutils/libcoreutils/getopt_mk_fifo_nod.c')
-rw-r--r--release/src/router/busybox/coreutils/libcoreutils/getopt_mk_fifo_nod.c29
1 files changed, 16 insertions, 13 deletions
diff --git a/release/src/router/busybox/coreutils/libcoreutils/getopt_mk_fifo_nod.c b/release/src/router/busybox/coreutils/libcoreutils/getopt_mk_fifo_nod.c
index 0872bdcf..ba3222e4 100644
--- a/release/src/router/busybox/coreutils/libcoreutils/getopt_mk_fifo_nod.c
+++ b/release/src/router/busybox/coreutils/libcoreutils/getopt_mk_fifo_nod.c
@@ -20,26 +20,29 @@
*
*/
-#include <sys/types.h>
-#include <sys/stat.h>
-#include <unistd.h>
#include "libbb.h"
#include "coreutils.h"
-extern mode_t getopt_mk_fifo_nod(int argc, char **argv)
+mode_t FAST_FUNC getopt_mk_fifo_nod(char **argv)
{
mode_t mode = 0666;
+ char *smode = NULL;
+#if ENABLE_SELINUX
+ security_context_t scontext;
+#endif
int opt;
+ opt = getopt32(argv, "m:" USE_SELINUX("Z:"), &smode USE_SELINUX(,&scontext));
+ if (opt & 1) {
+ if (bb_parse_mode(smode, &mode))
+ umask(0);
+ }
- while ((opt = getopt(argc, argv, "m:")) > 0) {
- if (opt == 'm') {
- mode = 0666;
- if (bb_parse_mode(optarg, &mode)) {
- umask(0);
- continue;
- }
- }
- bb_show_usage();
+#if ENABLE_SELINUX
+ if (opt & 2) {
+ selinux_or_die();
+ setfscreatecon_or_die(scontext);
}
+#endif
+
return mode;
}