Blame SOURCES/pam-1.1.8-lastlog-uninitialized.patch

f2fdff
diff -up Linux-PAM-1.1.8/modules/pam_lastlog/pam_lastlog.c.uninitialized Linux-PAM-1.1.8/modules/pam_lastlog/pam_lastlog.c
f2fdff
--- Linux-PAM-1.1.8/modules/pam_lastlog/pam_lastlog.c.uninitialized	2013-06-18 16:11:21.000000000 +0200
f2fdff
+++ Linux-PAM-1.1.8/modules/pam_lastlog/pam_lastlog.c	2014-08-25 16:44:24.365174752 +0200
f2fdff
@@ -350,6 +350,8 @@ last_login_write(pam_handle_t *pamh, int
f2fdff
 	return PAM_SERVICE_ERR;
f2fdff
     }
f2fdff
 
f2fdff
+    memset(&last_login, 0, sizeof(last_login));
f2fdff
+
f2fdff
     /* set this login date */
f2fdff
     D(("set the most recent login time"));
f2fdff
     (void) time(&ll_time);    /* set the time */
f2fdff
@@ -364,14 +366,12 @@ last_login_write(pam_handle_t *pamh, int
f2fdff
     }
f2fdff
 
f2fdff
     /* copy to last_login */
f2fdff
-    last_login.ll_host[0] = '\0';
f2fdff
     strncat(last_login.ll_host, remote_host, sizeof(last_login.ll_host)-1);
f2fdff
 
f2fdff
     /* set the terminal line */
f2fdff
     terminal_line = get_tty(pamh);
f2fdff
 
f2fdff
     /* copy to last_login */
f2fdff
-    last_login.ll_line[0] = '\0';
f2fdff
     strncat(last_login.ll_line, terminal_line, sizeof(last_login.ll_line)-1);
f2fdff
     terminal_line = NULL;
f2fdff
 
f2fdff
@@ -628,7 +628,8 @@ pam_sm_authenticate(pam_handle_t *pamh,
f2fdff
     lltime = (time(NULL) - lltime) / (24*60*60);
f2fdff
 
f2fdff
     if (lltime > inactive_days) {
f2fdff
-        pam_syslog(pamh, LOG_INFO, "user %s inactive for %d days - denied", user, lltime);
f2fdff
+        pam_syslog(pamh, LOG_INFO, "user %s inactive for %ld days - denied",
f2fdff
+		   user, (long) lltime);
f2fdff
         return PAM_AUTH_ERR;
f2fdff
     }
f2fdff