diff options
author | Thordur I. Bjornsson <thib@cvs.openbsd.org> | 2010-07-08 08:12:49 +0000 |
---|---|---|
committer | Thordur I. Bjornsson <thib@cvs.openbsd.org> | 2010-07-08 08:12:49 +0000 |
commit | 55c325e73a370ae4bb46ad813b59a219dbc525c0 (patch) | |
tree | 8563865ccef719c1526e8c82fae98cb0ba9287e5 | |
parent | f67aa7224b80cdcc71d1144ca25784f2b2adf384 (diff) |
Move pool initialization to init_crypto and zap the crypto_pool_initialized
variable. This way we don't have to check if the pool are initialized every
time we do a crypto_getreq().
Move splvm lower as it isnt need all through crypto_newsession().
tiny KNF nit.
From mikeb
OK deraadt@
-rw-r--r-- | sys/crypto/crypto.c | 25 |
1 files changed, 9 insertions, 16 deletions
diff --git a/sys/crypto/crypto.c b/sys/crypto/crypto.c index 35813c437f6..48dbee25c84 100644 --- a/sys/crypto/crypto.c +++ b/sys/crypto/crypto.c @@ -1,4 +1,4 @@ -/* $OpenBSD: crypto.c,v 1.54 2010/06/09 19:38:19 thib Exp $ */ +/* $OpenBSD: crypto.c,v 1.55 2010/07/08 08:12:48 thib Exp $ */ /* * The author of this code is Angelos D. Keromytis (angelos@cis.upenn.edu) * @@ -35,7 +35,6 @@ int crypto_drivers_num = 0; struct pool cryptop_pool; struct pool cryptodesc_pool; -int crypto_pool_initialized = 0; struct workq *crypto_workq; @@ -53,8 +52,6 @@ crypto_newsession(u_int64_t *sid, struct cryptoini *cri, int hard) if (crypto_drivers == NULL) return EINVAL; - s = splvm(); - /* * The algorithm we use here is pretty stupid; just use the * first driver that supports all the algorithms we need. Do @@ -149,10 +146,10 @@ crypto_newsession(u_int64_t *sid, struct cryptoini *cri, int hard) * XXX layer right about here. */ - if (hid == -1) { - splx(s); + if (hid == -1) return EINVAL; - } + + s = splvm(); /* Call the driver initialization routine. */ lid = hid; /* Pass the driver ID. */ @@ -593,14 +590,6 @@ crypto_getreq(int num) s = splvm(); - if (crypto_pool_initialized == 0) { - pool_init(&cryptop_pool, sizeof(struct cryptop), 0, 0, - 0, "cryptop", NULL); - pool_init(&cryptodesc_pool, sizeof(struct cryptodesc), 0, 0, - 0, "cryptodesc", NULL); - crypto_pool_initialized = 1; - } - crp = pool_get(&cryptop_pool, PR_NOWAIT); if (crp == NULL) { splx(s); @@ -626,8 +615,12 @@ crypto_getreq(int num) } void -init_crypto() +init_crypto(void) { + pool_init(&cryptop_pool, sizeof(struct cryptop), 0, 0, 0, + "cryptop", NULL); + pool_init(&cryptodesc_pool, sizeof(struct cryptodesc), 0, 0, 0, + "cryptodesc", NULL); crypto_workq = workq_create("crypto", 1, IPL_HIGH); } |