[PATCH v1 3/4] ipv6: sr: factor seg6_hmac_init_algo()'s per-algo code into separate function
From: Nicolai Stange
Date: Mon Mar 10 2025 - 13:00:25 EST
In order to prepare for ignoring certain instantiation failures and
continue with the remaining supported algorithms, factor the per-algo
initialization code into a separate function:
- rename seg6_hmac_init_algo() to seg6_hmac_init_algos() and
- move its per-algo initialization code into a new function,
seg6_hmac_init_algo().
This is a refactoring only, there is no change in behaviour.
Signed-off-by: Nicolai Stange <nstange@xxxxxxx>
---
net/ipv6/seg6_hmac.c | 88 ++++++++++++++++++++++++--------------------
1 file changed, 49 insertions(+), 39 deletions(-)
diff --git a/net/ipv6/seg6_hmac.c b/net/ipv6/seg6_hmac.c
index 2d7a400e074f..85e90d8d8050 100644
--- a/net/ipv6/seg6_hmac.c
+++ b/net/ipv6/seg6_hmac.c
@@ -380,51 +380,61 @@ static void seg6_hmac_free_algo(struct seg6_hmac_algo *algo)
}
}
-static int seg6_hmac_init_algo(void)
+static int seg6_hmac_init_algo(struct seg6_hmac_algo *algo)
{
- struct seg6_hmac_algo *algo;
- struct crypto_shash *tfm;
+ struct crypto_shash *tfm, **p_tfm;
struct shash_desc *shash;
- int i, alg_count, cpu;
+ int cpu, shsize;
int ret = -ENOMEM;
+ algo->tfms = alloc_percpu(struct crypto_shash *);
+ if (!algo->tfms)
+ goto error_out;
+
+ for_each_possible_cpu(cpu) {
+ tfm = crypto_alloc_shash(algo->name, 0, 0);
+ if (IS_ERR(tfm)) {
+ ret = PTR_ERR(tfm);
+ goto error_out;
+ }
+ p_tfm = per_cpu_ptr(algo->tfms, cpu);
+ *p_tfm = tfm;
+ }
+
+ p_tfm = raw_cpu_ptr(algo->tfms);
+ tfm = *p_tfm;
+
+ shsize = sizeof(*shash) + crypto_shash_descsize(tfm);
+
+ algo->shashs = alloc_percpu(struct shash_desc *);
+ if (!algo->shashs)
+ goto error_out;
+
+ for_each_possible_cpu(cpu) {
+ shash = kzalloc_node(shsize, GFP_KERNEL,
+ cpu_to_node(cpu));
+ if (!shash)
+ goto error_out;
+ *per_cpu_ptr(algo->shashs, cpu) = shash;
+ }
+
+ return 0;
+
+error_out:
+ seg6_hmac_free_algo(algo);
+ return ret;
+}
+
+static int seg6_hmac_init_algos(void)
+{
+ int i, alg_count;
+ int ret;
+
alg_count = ARRAY_SIZE(hmac_algos);
-
for (i = 0; i < alg_count; i++) {
- struct crypto_shash **p_tfm;
- int shsize;
-
- algo = &hmac_algos[i];
- algo->tfms = alloc_percpu(struct crypto_shash *);
- if (!algo->tfms)
+ ret = seg6_hmac_init_algo(&hmac_algos[i]);
+ if (ret)
goto error_out;
-
- for_each_possible_cpu(cpu) {
- tfm = crypto_alloc_shash(algo->name, 0, 0);
- if (IS_ERR(tfm)) {
- ret = PTR_ERR(tfm);
- goto error_out;
- }
- p_tfm = per_cpu_ptr(algo->tfms, cpu);
- *p_tfm = tfm;
- }
-
- p_tfm = raw_cpu_ptr(algo->tfms);
- tfm = *p_tfm;
-
- shsize = sizeof(*shash) + crypto_shash_descsize(tfm);
-
- algo->shashs = alloc_percpu(struct shash_desc *);
- if (!algo->shashs)
- goto error_out;
-
- for_each_possible_cpu(cpu) {
- shash = kzalloc_node(shsize, GFP_KERNEL,
- cpu_to_node(cpu));
- if (!shash)
- goto error_out;
- *per_cpu_ptr(algo->shashs, cpu) = shash;
- }
}
return 0;
@@ -436,7 +446,7 @@ static int seg6_hmac_init_algo(void)
int __init seg6_hmac_init(void)
{
- return seg6_hmac_init_algo();
+ return seg6_hmac_init_algos();
}
int __net_init seg6_hmac_net_init(struct net *net)
--
2.47.1