]> git.ipfire.org Git - thirdparty/util-linux.git/commitdiff
sulogin: use alarm function to indicate if a timeout occurs
authorWerner Fink <werner@suse.de>
Fri, 7 Dec 2012 08:00:56 +0000 (09:00 +0100)
committerKarel Zak <kzak@redhat.com>
Tue, 18 Dec 2012 14:08:04 +0000 (15:08 +0100)
A small change to use the alarm handler to indicate if a timeout occurs.

Signed-off-by: Werner Fink <werner@suse.de>
login-utils/sulogin.c

index db783a2a00fd0494b63940ef9a9979374ffd8f55..9fdbb69c75fdd056ddb3bb3cc5606298642d6307 100644 (file)
@@ -8,6 +8,7 @@
  *
  * Copyright (C) 1998-2003 Miquel van Smoorenburg.
  * Copyright (C) 2012 Karel Zak <kzak@redhat.com>
+ * Copyright (C) 2012 Werner Fink <werner@suse.de>
  *
  * This program is free software; you can redistribute it and/or modify
  * it under the terms of the GNU General Public License as published by
@@ -60,12 +61,15 @@ struct sigaction saved_sigint;
 struct sigaction saved_sigtstp;
 struct sigaction saved_sigquit;
 
+static volatile sig_atomic_t alarm_rised;
+
 /*
  * Called at timeout.
  */
 static void alrm_handler(int sig __attribute__((unused)))
 {
-       return;
+       /* Timeout expired */
+       alarm_rised++;
 }
 
 static void mask_signal(int signal, void (*handler)(int),
@@ -594,17 +598,27 @@ int main(int argc, char **argv)
         * Ask for the password.
         */
        while (pwd) {
+               int failed = 0;
                if ((p = getpasswd(pwd->pw_passwd)) == NULL)
                        break;
                if (pwd->pw_passwd[0] == 0 ||
-                   strcmp(crypt(p, pwd->pw_passwd), pwd->pw_passwd) == 0)
+                   strcmp(crypt(p, pwd->pw_passwd), pwd->pw_passwd) == 0) {
                        sushell(pwd);
+                       failed++;
+               }
                mask_signal(SIGQUIT, SIG_IGN, &saved_sigquit);
                mask_signal(SIGTSTP, SIG_IGN, &saved_sigtstp);
                mask_signal(SIGINT,  SIG_IGN, &saved_sigint);
-               fprintf(stderr, _("Login incorrect\n\n"));
+               if (failed) {
+                   fprintf(stderr, _("Can not execute su shell\n\n"));
+                   break;
+               } else
+                   fprintf(stderr, _("Login incorrect\n\n"));
        }
 
+       if (alarm_rised)
+               fprintf(stderr, _("Timed out\n\n"));
+
        /*
         * User pressed Control-D.
         */