lib: crc32: conditionally resched when running testcases
authorDaniel Borkmann <dborkman@redhat.com>
Mon, 4 Nov 2013 16:10:26 +0000 (17:10 +0100)
committerDavid S. Miller <davem@davemloft.net>
Mon, 4 Nov 2013 20:27:08 +0000 (15:27 -0500)
Fengguang reports that when crc32 selftests are running on startup, on
some e.g. 32bit systems, we can get a CPU stall like "INFO: rcu_sched
self-detected stall on CPU { 0} (t=2101 jiffies g=4294967081 c=4294967080
q=41)". As this is not intended, add a cond_resched() at the end of a
test case to fix it. Introduced by efba721f63 ("lib: crc32: add test cases
for crc32{, c}_combine routines").

Reported-by: Fengguang Wu <fengguang.wu@intel.com>
Signed-off-by: Daniel Borkmann <dborkman@redhat.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
lib/crc32.c

index 69dd124f0cfcf83bcea75a93637f87bb9ffef1b0..3a1dfa84203cc78c3d35cb0bc7d81fb7ca57115e 100644 (file)
@@ -29,6 +29,7 @@
 #include <linux/crc32.h>
 #include <linux/module.h>
 #include <linux/types.h>
+#include <linux/sched.h>
 #include "crc32defs.h"
 
 #if CRC_LE_BITS > 8
@@ -1054,6 +1055,7 @@ static int __init crc32c_combine_test(void)
                              crc_full == test[i].crc32c_le))
                                errors++;
                        runs++;
+                       cond_resched();
                }
        }
 
@@ -1147,6 +1149,7 @@ static int __init crc32_combine_test(void)
                              crc_full == test[i].crc_le))
                                errors++;
                        runs++;
+                       cond_resched();
                }
        }