aboutsummaryrefslogtreecommitdiff
path: root/libpam
diff options
context:
space:
mode:
authorAndrey Kovalev <ded@altlinux.org>2024-10-18 10:25:17 +0300
committerDmitry V. Levin <ldv@strace.io>2024-10-18 08:00:00 +0000
commit43bdb7ce04c9cb00bdf0f5dda818b077b9dc7c56 (patch)
tree0bb54c65e292f5ab060968d5d1168f1d33a86953 /libpam
parent29c390c7e5c7ee12a1beebd7458aed2fcba53f91 (diff)
downloadpam-43bdb7ce04c9cb00bdf0f5dda818b077b9dc7c56.tar.gz
pam-43bdb7ce04c9cb00bdf0f5dda818b077b9dc7c56.tar.bz2
pam-43bdb7ce04c9cb00bdf0f5dda818b077b9dc7c56.zip
pam_get_authtok*: disallow setting pamh to NULL
This also prevents a potential NULL pointer dereference in pam_get_authtok_internal and pam_get_authtok_verify when the pamh argument they access is set to NULL.
Diffstat (limited to 'libpam')
-rw-r--r--libpam/pam_get_authtok.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/libpam/pam_get_authtok.c b/libpam/pam_get_authtok.c
index c8973275..2e7a5996 100644
--- a/libpam/pam_get_authtok.c
+++ b/libpam/pam_get_authtok.c
@@ -84,6 +84,8 @@ pam_get_authtok_internal (pam_handle_t *pamh, int item,
unsigned int flags)
{
+ IF_NO_PAMH(pamh, PAM_SYSTEM_ERR);
+
char *resp[2] = {NULL, NULL};
const void *prevauthtok;
const char *authtok_type = "";
@@ -229,6 +231,8 @@ int
pam_get_authtok_verify (pam_handle_t *pamh, const char **authtok,
const char *prompt)
{
+ IF_NO_PAMH(pamh, PAM_SYSTEM_ERR);
+
char *resp = NULL;
const char *authtok_type = "";
int retval;