Commit c23d7997 authored by Geert Uytterhoeven's avatar Geert Uytterhoeven Committed by Herbert Xu

crypto: ccree - remove struct cc_cipher_handle

The cc_cipher_handle structure contains only a single member, and only
one instance exists.  Simplify the code and reduce memory consumption by
moving this member to struct cc_drvdata.
Signed-off-by: default avatarGeert Uytterhoeven <geert+renesas@glider.be>
Signed-off-by: default avatarHerbert Xu <herbert@gondor.apana.org.au>
parent 040187a0
...@@ -20,10 +20,6 @@ ...@@ -20,10 +20,6 @@
#define template_skcipher template_u.skcipher #define template_skcipher template_u.skcipher
struct cc_cipher_handle {
struct list_head alg_list;
};
struct cc_user_key_info { struct cc_user_key_info {
u8 *key; u8 *key;
dma_addr_t key_dma_addr; dma_addr_t key_dma_addr;
...@@ -1661,36 +1657,24 @@ static struct cc_crypto_alg *cc_create_alg(const struct cc_alg_template *tmpl, ...@@ -1661,36 +1657,24 @@ static struct cc_crypto_alg *cc_create_alg(const struct cc_alg_template *tmpl,
int cc_cipher_free(struct cc_drvdata *drvdata) int cc_cipher_free(struct cc_drvdata *drvdata)
{ {
struct cc_crypto_alg *t_alg, *n; struct cc_crypto_alg *t_alg, *n;
struct cc_cipher_handle *cipher_handle = drvdata->cipher_handle;
/* Remove registered algs */
if (cipher_handle) { list_for_each_entry_safe(t_alg, n, &drvdata->alg_list, entry) {
/* Remove registered algs */ crypto_unregister_skcipher(&t_alg->skcipher_alg);
list_for_each_entry_safe(t_alg, n, &cipher_handle->alg_list, list_del(&t_alg->entry);
entry) { kfree(t_alg);
crypto_unregister_skcipher(&t_alg->skcipher_alg);
list_del(&t_alg->entry);
kfree(t_alg);
}
kfree(cipher_handle);
drvdata->cipher_handle = NULL;
} }
return 0; return 0;
} }
int cc_cipher_alloc(struct cc_drvdata *drvdata) int cc_cipher_alloc(struct cc_drvdata *drvdata)
{ {
struct cc_cipher_handle *cipher_handle;
struct cc_crypto_alg *t_alg; struct cc_crypto_alg *t_alg;
struct device *dev = drvdata_to_dev(drvdata); struct device *dev = drvdata_to_dev(drvdata);
int rc = -ENOMEM; int rc = -ENOMEM;
int alg; int alg;
cipher_handle = kmalloc(sizeof(*cipher_handle), GFP_KERNEL); INIT_LIST_HEAD(&drvdata->alg_list);
if (!cipher_handle)
return -ENOMEM;
INIT_LIST_HEAD(&cipher_handle->alg_list);
drvdata->cipher_handle = cipher_handle;
/* Linux crypto */ /* Linux crypto */
dev_dbg(dev, "Number of algorithms = %zu\n", dev_dbg(dev, "Number of algorithms = %zu\n",
...@@ -1722,8 +1706,7 @@ int cc_cipher_alloc(struct cc_drvdata *drvdata) ...@@ -1722,8 +1706,7 @@ int cc_cipher_alloc(struct cc_drvdata *drvdata)
kfree(t_alg); kfree(t_alg);
goto fail0; goto fail0;
} else { } else {
list_add_tail(&t_alg->entry, list_add_tail(&t_alg->entry, &drvdata->alg_list);
&cipher_handle->alg_list);
dev_dbg(dev, "Registered %s\n", dev_dbg(dev, "Registered %s\n",
t_alg->skcipher_alg.base.cra_driver_name); t_alg->skcipher_alg.base.cra_driver_name);
} }
......
...@@ -141,7 +141,7 @@ struct cc_drvdata { ...@@ -141,7 +141,7 @@ struct cc_drvdata {
struct platform_device *plat_dev; struct platform_device *plat_dev;
u32 mlli_sram_addr; u32 mlli_sram_addr;
struct dma_pool *mlli_buffs_pool; struct dma_pool *mlli_buffs_pool;
void *cipher_handle; struct list_head alg_list;
void *hash_handle; void *hash_handle;
void *aead_handle; void *aead_handle;
void *request_mgr_handle; void *request_mgr_handle;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment