From: Greg Hudson Date: Wed, 23 Jun 2021 20:57:39 +0000 (-0400) Subject: Clean up context after failed open in libkdb5 X-Git-Tag: krb5-1.20-beta1~76 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=refs%2Fpull%2F1198%2Fhead;p=thirdparty%2Fkrb5.git Clean up context after failed open in libkdb5 If krb5_db_open() or krb5_db_create() fails, release the dal_handle, as the caller is unlikely to call krb5_db_close() after a failure. --- diff --git a/src/lib/kdb/kdb5.c b/src/lib/kdb/kdb5.c index 47e9b31a7b..11e2430c43 100644 --- a/src/lib/kdb/kdb5.c +++ b/src/lib/kdb/kdb5.c @@ -675,6 +675,8 @@ krb5_db_open(krb5_context kcontext, char **db_args, int mode) return status; status = v->init_module(kcontext, section, db_args, mode); free(section); + if (status) + (void)krb5_db_fini(kcontext); return status; } @@ -702,6 +704,8 @@ krb5_db_create(krb5_context kcontext, char **db_args) return status; status = v->create(kcontext, section, db_args); free(section); + if (status) + (void)krb5_db_fini(kcontext); return status; }