summaryrefslogtreecommitdiffstats
path: root/lib/libpam/modules/pam_lastlog/pam_lastlog.c
diff options
context:
space:
mode:
authordes <des@FreeBSD.org>2003-12-11 13:55:16 +0000
committerdes <des@FreeBSD.org>2003-12-11 13:55:16 +0000
commit9c38a557979e384e5fc0e3b85507242bee98321f (patch)
tree79f074d7b6c050b037a9004caf920936f5c2abf9 /lib/libpam/modules/pam_lastlog/pam_lastlog.c
parent0b146f01b2bf8034a394e4136235609dddda45bf (diff)
downloadFreeBSD-src-9c38a557979e384e5fc0e3b85507242bee98321f.zip
FreeBSD-src-9c38a557979e384e5fc0e3b85507242bee98321f.tar.gz
Fix strict aliasing breakage in PAM modules (except pam_krb5, which needs
more work than the others). This should make most modules build with -O2.
Diffstat (limited to 'lib/libpam/modules/pam_lastlog/pam_lastlog.c')
-rw-r--r--lib/libpam/modules/pam_lastlog/pam_lastlog.c15
1 files changed, 8 insertions, 7 deletions
diff --git a/lib/libpam/modules/pam_lastlog/pam_lastlog.c b/lib/libpam/modules/pam_lastlog/pam_lastlog.c
index 200f489..9a1daf2 100644
--- a/lib/libpam/modules/pam_lastlog/pam_lastlog.c
+++ b/lib/libpam/modules/pam_lastlog/pam_lastlog.c
@@ -72,7 +72,8 @@ pam_sm_open_session(pam_handle_t *pamh, int flags,
struct utmp utmp;
struct lastlog ll;
time_t t;
- const char *rhost, *user, *tty;
+ const char *user;
+ const void *rhost, *tty;
off_t llpos;
int fd, pam_err;
@@ -83,10 +84,10 @@ pam_sm_open_session(pam_handle_t *pamh, int flags,
return (PAM_SERVICE_ERR);
PAM_LOG("Got user: %s", user);
- pam_err = pam_get_item(pamh, PAM_RHOST, (const void **)&rhost);
+ pam_err = pam_get_item(pamh, PAM_RHOST, &rhost);
if (pam_err != PAM_SUCCESS)
goto err;
- pam_err = pam_get_item(pamh, PAM_TTY, (const void **)&tty);
+ pam_err = pam_get_item(pamh, PAM_TTY, &tty);
if (pam_err != PAM_SUCCESS)
goto err;
if (tty == NULL) {
@@ -94,8 +95,8 @@ pam_sm_open_session(pam_handle_t *pamh, int flags,
goto err;
}
if (strncmp(tty, _PATH_DEV, strlen(_PATH_DEV)) == 0)
- tty += strlen(_PATH_DEV);
- if (*tty == '\0')
+ tty = (const char *)tty + strlen(_PATH_DEV);
+ if (*(const char *)tty == '\0')
return (PAM_SERVICE_ERR);
fd = open(_PATH_LASTLOG, O_RDWR|O_CREAT, 0644);
@@ -129,7 +130,7 @@ pam_sm_open_session(pam_handle_t *pamh, int flags,
/* note: does not need to be NUL-terminated */
strncpy(ll.ll_line, tty, sizeof(ll.ll_line));
- if (rhost != NULL && *rhost != '\0')
+ if (rhost != NULL && *(const char *)rhost != '\0')
/* note: does not need to be NUL-terminated */
strncpy(ll.ll_host, rhost, sizeof(ll.ll_host));
@@ -145,7 +146,7 @@ pam_sm_open_session(pam_handle_t *pamh, int flags,
utmp.ut_time = time(NULL);
/* note: does not need to be NUL-terminated */
strncpy(utmp.ut_name, user, sizeof(utmp.ut_name));
- if (rhost != NULL && *rhost != '\0')
+ if (rhost != NULL && *(const char *)rhost != '\0')
strncpy(utmp.ut_host, rhost, sizeof(utmp.ut_host));
(void)strncpy(utmp.ut_line, tty, sizeof(utmp.ut_line));
login(&utmp);
OpenPOWER on IntegriCloud