From a945f6190b9ffdd316e8590c0b4fcb25dee7676e Mon Sep 17 00:00:00 2001 From: Mike Frysinger Date: Mon, 22 Nov 2010 04:57:37 +0100 Subject: inetd: if argv[0] is not specified, set it to program name With inetd.conf files that skip argv[], inetd execs programs with argc==0. Signed-off-by: Mike Frysinger Signed-off-by: Denys Vlasenko --- networking/inetd.c | 6 ++++++ 1 file changed, 6 insertions(+) (limited to 'networking') diff --git a/networking/inetd.c b/networking/inetd.c index ac42c52..fb00c6c 100644 --- a/networking/inetd.c +++ b/networking/inetd.c @@ -778,6 +778,12 @@ static servtab_t *parse_one_line(void) argc = 0; while ((arg = token[6+argc]) != NULL && argc < MAXARGV) sep->se_argv[argc++] = xstrdup(arg); + /* Some inetd.conf files have no argv's, not even argv[0]. + * Fix them up. + * (Technically, programs can be execed with argv[0] = NULL, + * but many programs do not like that at all) */ + if (argc == 0) + sep->se_argv[0] = xstrdup(sep->se_program); /* catch mixups. " stream udp ..." == wtf */ if (sep->se_socktype == SOCK_STREAM) { -- cgit v1.1