crypto: pcrypt - Dont calulate a callback cpu on empty callback cpumask
authorSteffen Klassert <steffen.klassert@secunet.com>
Tue, 20 Jul 2010 06:52:20 +0000 (08:52 +0200)
committerHerbert Xu <herbert@gondor.apana.org.au>
Mon, 26 Jul 2010 06:13:59 +0000 (14:13 +0800)
If the callback cpumask is empty, we crash with a division by zero
when we try to calculate a callback cpu. So we don't update the callback
cpu in pcrypt_do_parallel if the callback cpumask is empty.

Signed-off-by: Steffen Klassert <steffen.klassert@secunet.com>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
crypto/pcrypt.c

index 7153a50bce2775067ce4ca27e5ecc07b8372785e..794c172b99f765871a9b4a8583c11d73ec43dc63 100644 (file)
@@ -82,6 +82,9 @@ static int pcrypt_do_parallel(struct padata_priv *padata, unsigned int *cb_cpu,
        if (cpumask_test_cpu(cpu, cpumask->mask))
                        goto out;
 
+       if (!cpumask_weight(cpumask->mask))
+                       goto out;
+
        cpu_index = cpu % cpumask_weight(cpumask->mask);
 
        cpu = cpumask_first(cpumask->mask);