summaryrefslogtreecommitdiffstats
path: root/src/util/et/error_message.c
diff options
context:
space:
mode:
authorKen Raeburn <raeburn@mit.edu>2004-05-31 04:10:18 +0000
committerKen Raeburn <raeburn@mit.edu>2004-05-31 04:10:18 +0000
commitae7ae4f358a0d812eaf5b4e535b5471821a18371 (patch)
treecfe5744829b627cdb9e954d8cb3a639a74830cce /src/util/et/error_message.c
parent524da05167bbcaf31dde0ff60488191ade422f04 (diff)
downloadkrb5-ae7ae4f358a0d812eaf5b4e535b5471821a18371.tar.gz
krb5-ae7ae4f358a0d812eaf5b4e535b5471821a18371.tar.xz
krb5-ae7ae4f358a0d812eaf5b4e535b5471821a18371.zip
* error_message.c (terminated): New variable.
(com_err_terminate): Set it. (remove_error_table): Check it, warn and abort if set. git-svn-id: svn://anonsvn.mit.edu/krb5/trunk@16379 dc483132-0cff-0310-8789-dd5450dbe970
Diffstat (limited to 'src/util/et/error_message.c')
-rw-r--r--src/util/et/error_message.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/src/util/et/error_message.c b/src/util/et/error_message.c
index dd3c36fd08..e785172d92 100644
--- a/src/util/et/error_message.c
+++ b/src/util/et/error_message.c
@@ -57,6 +57,7 @@ int com_err_initialize(void)
return 0;
}
+static int terminated = 0; /* for debugging shlib fini sequence errors */
void com_err_terminate(void)
{
struct dynamic_et_list *e, *enext;
@@ -67,6 +68,7 @@ void com_err_terminate(void)
enext = e->next;
free(e);
}
+ terminated = 1;
}
#ifndef DEBUG_TABLE_LIST
@@ -301,6 +303,12 @@ remove_error_table(const struct error_table * et)
if (CALL_INIT_FUNCTION(com_err_initialize))
return 0;
+#if !defined(ENABLE_THREADS) && defined(DEBUG_THREADS)
+ if (et_list_lock.initialized == 0 && terminated != 0) {
+ fprintf(stderr, "\n\n *** Function remove_error_table called after com_err library termination. ***\n *** Shared library termination code executed in incorrect order? ***\n\n");
+ abort();
+ }
+#endif
merr = k5_mutex_lock(&et_list_lock);
if (merr)
return merr;