diff options
author | Simo Sorce <simo@redhat.com> | 2022-05-19 12:27:40 -0400 |
---|---|---|
committer | Greg Hudson <ghudson@mit.edu> | 2022-05-24 19:31:10 -0400 |
commit | 9efb48105d996232ab560a652ba9a01daf0f9a20 (patch) | |
tree | 2eeb3924f66157b423546bd6b5856f0a5b8bca7e | |
parent | 0794ad7614fba5827388c8ea6efff574c9a4ada1 (diff) | |
download | krb5-9efb48105d996232ab560a652ba9a01daf0f9a20.zip krb5-9efb48105d996232ab560a652ba9a01daf0f9a20.tar.gz krb5-9efb48105d996232ab560a652ba9a01daf0f9a20.tar.bz2 |
Read GSS configuration files with mtime 0
There is at least one case (with flatpaks) where configuration files
in the special read-only /etc all have an mtime of 0. Using an
initial last modified time of 0 in g_initialize.c causes these files
to never be read.
Change the initial high value to the be the "invalid" value
(time_t)-1. Since the C and POSIX standards do not require time_t to
be signed, special-case the checks in load_if_changed() and
updateMechList() to treat all mod times as newer than -1.
[ghudson@mit.edu: edited commit message; slightly modified approach]
(cherry picked from commit 2b34a007461065e0cab4490dfe1ae5ddd10da67b)
ticket: 9060
version_fixed: 1.20
-rw-r--r-- | src/lib/gssapi/mechglue/g_initialize.c | 11 |
1 files changed, 6 insertions, 5 deletions
diff --git a/src/lib/gssapi/mechglue/g_initialize.c b/src/lib/gssapi/mechglue/g_initialize.c index b26262d..22f6c61 100644 --- a/src/lib/gssapi/mechglue/g_initialize.c +++ b/src/lib/gssapi/mechglue/g_initialize.c @@ -93,7 +93,7 @@ static void free_mechSet(void); static gss_mech_info g_mechList = NULL; static gss_mech_info g_mechListTail = NULL; static k5_mutex_t g_mechListLock = K5_MUTEX_PARTIAL_INITIALIZER; -static time_t g_confFileModTime = (time_t)0; +static time_t g_confFileModTime = (time_t)-1; static time_t g_confLastCall = (time_t)0; static gss_OID_set_desc g_mechSet = { 0, NULL }; @@ -469,9 +469,9 @@ load_if_changed(const char *pathname, time_t last, time_t *highest) mtime = check_link_mtime(pathname, &mtime); if (mtime == (time_t)-1) return; - if (mtime > *highest) + if (mtime > *highest || *highest == (time_t)-1) *highest = mtime; - if (mtime > last) + if (mtime > last || last == (time_t)-1) loadConfigFile(pathname); } @@ -482,7 +482,7 @@ static void loadConfigFiles() { glob_t globbuf; - time_t highest = 0, now; + time_t highest = (time_t)-1, now; char **path; const char *val; @@ -522,7 +522,8 @@ updateMechList(void) #if defined(_WIN32) time_t lastConfModTime = getRegConfigModTime(MECH_KEY); - if (g_confFileModTime >= lastConfModTime) + if (g_confFileModTime >= lastConfModTime && + g_confFileModTime != (time_t)-1) return; g_confFileModTime = lastConfModTime; loadConfigFromRegistry(HKEY_CURRENT_USER, MECH_KEY); |