aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorMiro Jurisic <meeroh@mit.edu>2000-01-22 04:04:36 +0000
committerMiro Jurisic <meeroh@mit.edu>2000-01-22 04:04:36 +0000
commit3954dd2c1f9919e2ac09f86f022063119b5dd8d3 (patch)
tree4918d63eb6cb7427d398d6cac70bfa325ad29025 /src
parent41ff7485d2775407c85fb2b90b26c3170b2ad4b5 (diff)
downloadkrb5-3954dd2c1f9919e2ac09f86f022063119b5dd8d3.zip
krb5-3954dd2c1f9919e2ac09f86f022063119b5dd8d3.tar.gz
krb5-3954dd2c1f9919e2ac09f86f022063119b5dd8d3.tar.bz2
Moved krb5, gss, and crypto library initialization/cleanup code into new dedicated functions; added code to release global state allocated in prng.c
git-svn-id: svn://anonsvn.mit.edu/krb5/trunk@11960 dc483132-0cff-0310-8789-dd5450dbe970
Diffstat (limited to 'src')
-rw-r--r--src/lib/crypto/ChangeLog6
-rw-r--r--src/lib/crypto/Makefile.in3
-rw-r--r--src/lib/crypto/crypto_libinit.c30
-rw-r--r--src/lib/crypto/crypto_libinit.h7
-rw-r--r--src/lib/crypto/prng.c6
-rw-r--r--src/lib/gssapi/ChangeLog6
-rw-r--r--src/lib/gssapi/Makefile.in6
-rw-r--r--src/lib/gssapi/gss_libinit.c43
-rw-r--r--src/lib/gssapi/gss_libinit.h9
-rw-r--r--src/lib/krb5/ChangeLog6
-rw-r--r--src/lib/krb5/Makefile.in6
-rw-r--r--src/lib/krb5/krb5_libinit.c46
-rw-r--r--src/lib/krb5/krb5_libinit.h9
-rw-r--r--src/mac/GSS.CFM.c16
-rw-r--r--src/mac/K5.CFM.c31
15 files changed, 195 insertions, 35 deletions
diff --git a/src/lib/crypto/ChangeLog b/src/lib/crypto/ChangeLog
index 0c42368..957a0ec 100644
--- a/src/lib/crypto/ChangeLog
+++ b/src/lib/crypto/ChangeLog
@@ -1,3 +1,9 @@
+Fri Jan 21 22:47:00 2000 Miro Jurisic <meeroh@mit.edu>
+
+ * Makefile.in: added crypto_libinit.[co]
+ * crypto_libinit.[ch]: new files, contain library initialization
+ and cleanup code
+
2000-01-21 Ken Raeburn <raeburn@mit.edu>
* cksumtypes.c (krb5_cksumtypes_list, krb5_cksumtypes_length): Now
diff --git a/src/lib/crypto/Makefile.in b/src/lib/crypto/Makefile.in
index d86325b..71bddf5 100644
--- a/src/lib/crypto/Makefile.in
+++ b/src/lib/crypto/Makefile.in
@@ -26,6 +26,7 @@ STLIBOBJS=\
cksumtype_to_string.o \
cksumtypes.o \
coll_proof_cksum.o \
+ crypto_libinit.o \
decrypt.o \
encrypt.o \
encrypt_length.o \
@@ -53,6 +54,7 @@ OBJS=\
$(OUTPRE)cksumtype_to_string.$(OBJEXT) \
$(OUTPRE)cksumtypes.$(OBJEXT) \
$(OUTPRE)coll_proof_cksum.$(OBJEXT) \
+ $(OUTPRE)crypto_libinit.$(OBJEXT) \
$(OUTPRE)decrypt.$(OBJEXT) \
$(OUTPRE)encrypt.$(OBJEXT) \
$(OUTPRE)encrypt_length.$(OBJEXT) \
@@ -80,6 +82,7 @@ SRCS=\
$(subdir)/cksumtype_to_string.c \
$(subdir)/cksumtypes.c \
$(subdir)/coll_proof_cksum.c \
+ $(subdir)/crypto_libinit.c \
$(subdir)/decrypt.c \
$(subdir)/encrypt.c \
$(subdir)/encrypt_length.c \
diff --git a/src/lib/crypto/crypto_libinit.c b/src/lib/crypto/crypto_libinit.c
new file mode 100644
index 0000000..5ae277e
--- /dev/null
+++ b/src/lib/crypto/crypto_libinit.c
@@ -0,0 +1,30 @@
+#include <assert.h>
+
+static int initialized = false;
+
+/*
+ * Initialize the crypto library.
+ */
+
+int cryptoint_initialize_library (void)
+{
+
+ if (!initialized) {
+ initialized = true;
+ }
+
+ return 0;
+}
+
+/*
+ * Clean up the crypto library state
+ */
+
+void cryptoint_cleanup_library (void)
+{
+ assert (initialized);
+
+ prng_cleanup ();
+
+ initialized = false;
+} \ No newline at end of file
diff --git a/src/lib/crypto/crypto_libinit.h b/src/lib/crypto/crypto_libinit.h
new file mode 100644
index 0000000..3586a63
--- /dev/null
+++ b/src/lib/crypto/crypto_libinit.h
@@ -0,0 +1,7 @@
+#ifndef KRB5_LIBINIT_H
+#define KRB5_LIBINIT_H
+
+int cryptoint_initialize_library (void);
+void cryptoint_cleanup_library (void);
+
+#endif /* KRB5_LIBINIT_H */
diff --git a/src/lib/crypto/prng.c b/src/lib/crypto/prng.c
index c0f106f..6d401a9 100644
--- a/src/lib/crypto/prng.c
+++ b/src/lib/crypto/prng.c
@@ -153,3 +153,9 @@ krb5_c_random_make_octets(krb5_context context, krb5_data *data)
return(0);
}
+
+void prng_cleanup (void)
+{
+ free (random_state);
+ inited = 0;
+} \ No newline at end of file
diff --git a/src/lib/gssapi/ChangeLog b/src/lib/gssapi/ChangeLog
index 8f794fa..64f7f57 100644
--- a/src/lib/gssapi/ChangeLog
+++ b/src/lib/gssapi/ChangeLog
@@ -1,3 +1,9 @@
+Fri Jan 21 22:47:00 2000 Miro Jurisic <meeroh@mit.edu>
+
+ * Makefile.in: added gss_libinit.[co]
+ * gss_libinit.[ch]: new files, contain library initialization
+ and cleanup code
+
Tue May 18 19:52:56 1999 Danilo Almeida <dalmeida@mit.edu>
* Makefile.in: Remove - from recursive Win32 make invocation.
diff --git a/src/lib/gssapi/Makefile.in b/src/lib/gssapi/Makefile.in
index 992615d..5198aec 100644
--- a/src/lib/gssapi/Makefile.in
+++ b/src/lib/gssapi/Makefile.in
@@ -12,6 +12,12 @@ LOCAL_SUBDIRS= generic krb5
MAC_SUBDIRS = generic krb5
+OBJS=\
+ $(OUTPRE)gss_libinit.$(OBJEXT)
+
+SRCS=\
+ $(subdir)/gss_libinit.c
+
LIB=gssapi_krb5
LIBMAJOR=2
LIBMINOR=1
diff --git a/src/lib/gssapi/gss_libinit.c b/src/lib/gssapi/gss_libinit.c
new file mode 100644
index 0000000..ac91b0f
--- /dev/null
+++ b/src/lib/gssapi/gss_libinit.c
@@ -0,0 +1,43 @@
+#include <assert.h>
+
+#include "gssapi_err_generic.h"
+#include "gssapi_err_krb5.h"
+
+#include "gss_libinit.h"
+
+static int initialized = false;
+
+/*
+ * Initialize the GSSAPI library.
+ */
+
+OM_uint32 gssint_initialize_library (void)
+{
+
+ if (!initialized) {
+ add_error_table(&et_k5g_error_table);
+ add_error_table(&et_ggss_error_table);
+
+ initialized = true;
+ }
+
+ return 0;
+}
+
+/*
+ * Clean up the Kerberos v5 lirbary state
+ */
+
+void gssint_cleanup_library (void)
+{
+ OM_uint32 maj_stat, min_stat;
+
+ assert (initialized);
+
+ maj_stat = kg_release_defcred (&min_stat);
+
+ remove_error_table(&et_k5g_error_table);
+ remove_error_table(&et_ggss_error_table);
+
+ initialized = false;
+} \ No newline at end of file
diff --git a/src/lib/gssapi/gss_libinit.h b/src/lib/gssapi/gss_libinit.h
new file mode 100644
index 0000000..ba89ff3
--- /dev/null
+++ b/src/lib/gssapi/gss_libinit.h
@@ -0,0 +1,9 @@
+#ifndef KRB5_LIBINIT_H
+#define KRB5_LIBINIT_H
+
+#include "gssapi.h"
+
+OM_uint32 gssint_initialize_library (void);
+void gssint_cleanup_library (void);
+
+#endif /* KRB5_LIBINIT_H */
diff --git a/src/lib/krb5/ChangeLog b/src/lib/krb5/ChangeLog
index b11d309..5cb8464 100644
--- a/src/lib/krb5/ChangeLog
+++ b/src/lib/krb5/ChangeLog
@@ -1,3 +1,9 @@
+Fri Jan 21 22:47:00 2000 Miro Jurisic <meeroh@mit.edu>
+
+ * Makefile.in: added krb5_libinit.[co]
+ * krb5_libinit.[ch]: new files, contain library initialization
+ and cleanup code
+
1999-12-01 Ken Raeburn <raeburn@mit.edu>
* Makefile.in (LIBMINOR): Update to 2.
diff --git a/src/lib/krb5/Makefile.in b/src/lib/krb5/Makefile.in
index 4235d72..b03b623 100644
--- a/src/lib/krb5/Makefile.in
+++ b/src/lib/krb5/Makefile.in
@@ -45,6 +45,12 @@ STOBJLISTS= \
posix/OBJS.ST \
$(BUILDTOP)/util/profile/OBJS.ST
+OBJS=\
+ $(OUTPRE)krb5_libinit.$(OBJEXT)
+
+SRCS=\
+ $(subdir)/krb5_libinit.c
+
RELDIR=krb5
SHLIB_EXPDEPS = \
$(TOPLIBD)/libk5crypto$(SHLIBEXT) \
diff --git a/src/lib/krb5/krb5_libinit.c b/src/lib/krb5/krb5_libinit.c
new file mode 100644
index 0000000..584aa57
--- /dev/null
+++ b/src/lib/krb5/krb5_libinit.c
@@ -0,0 +1,46 @@
+#include <assert.h>
+
+#include "krb5.h"
+#include "krb5_err.h"
+#include "kv5m_err.h"
+#include "asn1_err.h"
+#include "kdb5_err.h"
+
+static int initialized = false;
+
+/*
+ * Initialize the Kerberos v5 library.
+ */
+
+krb5_error_code krb5int_initialize_library (void)
+{
+
+ if (!initialized) {
+ add_error_table(&et_krb5_error_table);
+ add_error_table(&et_kv5m_error_table);
+ add_error_table(&et_kdb5_error_table);
+ add_error_table(&et_asn1_error_table);
+
+ initialized = true;
+ }
+
+ return 0;
+}
+
+/*
+ * Clean up the Kerberos v5 lirbary state
+ */
+
+void krb5int_cleanup_library (void)
+{
+ assert (initialized);
+
+ krb5_stdcc_shutdown();
+
+ remove_error_table(&et_krb5_error_table);
+ remove_error_table(&et_kv5m_error_table);
+ remove_error_table(&et_kdb5_error_table);
+ remove_error_table(&et_asn1_error_table);
+
+ initialized = false;
+} \ No newline at end of file
diff --git a/src/lib/krb5/krb5_libinit.h b/src/lib/krb5/krb5_libinit.h
new file mode 100644
index 0000000..11d7248
--- /dev/null
+++ b/src/lib/krb5/krb5_libinit.h
@@ -0,0 +1,9 @@
+#ifndef KRB5_LIBINIT_H
+#define KRB5_LIBINIT_H
+
+#include "krb5.h"
+
+krb5_error_code krb5int_initialize_library (void);
+void krb5int_cleanup_library (void);
+
+#endif /* KRB5_LIBINIT_H */
diff --git a/src/mac/GSS.CFM.c b/src/mac/GSS.CFM.c
index a7c7c64..985ccd2 100644
--- a/src/mac/GSS.CFM.c
+++ b/src/mac/GSS.CFM.c
@@ -19,10 +19,7 @@
#include <CodeFragments.h>
-#include "gssapi_err_generic.h"
-#include "gssapi_err_krb5.h"
-
-#include "gssapi.h"
+#include "gss_libinit.h"
OSErr __initializeGSS(CFragInitBlockPtr ibp);
void __terminateGSS(void);
@@ -36,8 +33,7 @@ OSErr __initializeGSS(CFragInitBlockPtr ibp)
/* Initialize the error tables */
if (err == noErr) {
- add_error_table(&et_k5g_error_table);
- add_error_table(&et_ggss_error_table);
+ err = gssint_initialize_library ();
}
return err;
@@ -45,13 +41,7 @@ OSErr __initializeGSS(CFragInitBlockPtr ibp)
void __terminateGSS(void)
{
-
- OM_uint32 maj_stat, min_stat;
-
- maj_stat = kg_release_defcred (&min_stat);
-
- remove_error_table(&et_k5g_error_table);
- remove_error_table(&et_ggss_error_table);
+ gssint_cleanup_library ();
__terminate();
}
diff --git a/src/mac/K5.CFM.c b/src/mac/K5.CFM.c
index 57d1fbb..efb918c 100644
--- a/src/mac/K5.CFM.c
+++ b/src/mac/K5.CFM.c
@@ -19,12 +19,8 @@
#include <CodeFragments.h>
-#include "krb5_err.h"
-#include "kv5m_err.h"
-#include "asn1_err.h"
-#include "kdb5_err.h"
-#include "profile.h"
-#include "adm_err.h"
+#include "krb5_libinit.h"
+#include "crypto_libinit.h"
OSErr __initializeK5(CFragInitBlockPtr ibp);
@@ -34,17 +30,14 @@ OSErr __initializeK5(CFragInitBlockPtr ibp)
{
OSErr err = noErr;
- /* Do normal init of the shared library */
err = __initialize();
- /* Initialize the error tables */
if (err == noErr) {
- add_error_table(&et_krb5_error_table);
- add_error_table(&et_kv5m_error_table);
- add_error_table(&et_kdb5_error_table);
- add_error_table(&et_asn1_error_table);
-// add_error_table(&et_prof_error_table);
- add_error_table(&et_kadm_error_table);
+ err = krb5int_initialize_library ();
+ }
+
+ if (err == noErr) {
+ err = cryptoint_initialize_library ();
}
return err;
@@ -53,14 +46,8 @@ OSErr __initializeK5(CFragInitBlockPtr ibp)
void __terminateK5(void)
{
- krb5_stdcc_shutdown();
-
- remove_error_table(&et_krb5_error_table);
- remove_error_table(&et_kv5m_error_table);
- remove_error_table(&et_kdb5_error_table);
- remove_error_table(&et_asn1_error_table);
-// remove_error_table(&et_prof_error_table);
- remove_error_table(&et_kadm_error_table);
+ cryptoint_cleanup_library ();
+ krb5int_cleanup_library ();
__terminate();
}