Thread (23 messages) 23 messages, 7 authors, 2018-07-17

Re: [PATCH 4/4] lib/test_crc: Add test cases for crc calculation

From: Coly Li <hidden>
Date: 2018-07-17 04:39:10
Also in: lkml

On 2018/7/17 4:47 AM, Andy Shevchenko wrote:
On Mon, Jul 16, 2018 at 7:55 PM, Coly Li [off-list ref] wrote:
quoted
This patch adds a kernel module to test the consistency of multiple crc
calculation in Linux kernel. It is enabled with CONFIG_TEST_CRC enabled.

The test results are printed into kernel message, which look like,

test_crc: crc64_le: PASSED (0x4e6b> +
1ff972fa8c55, expval 0x4e6b1ff972fa8c55)
quoted
test_crc: crc64_le_bch: PASSED (0x0e4f1391d7a4a62e, expval 0x0e4f1391d7a4a62e)
test_crc: crc64_le_update: FAILED (0x03d4d0d85685d9a1, expval 0x3d4d0d85685d9a1f)

kernel 0day system has framework to check kernel message, then the above
result can be handled by 0day system. If crc calculation inconsistency
happens, it can be detected quite soon.

lib/test_crc.c can is a testing frame work for all crc consistency
testings. For now, there are only test caes for 3 crc routines,
- crc64_le()
- crc64_le_bch()
- crc64_le_update()
quoted
+config TEST_CRC
+       tristate "CRC calculation test driver"
Hi Andy,
quoted
+       default n
Default default is n.
I see TEST_FIRMWARE, TEST_SYSCTL, TEST_UDELAY, TEST_STATIC_KEYS arround
TEST_CRC all have 'default n', then I think to follow the style it might
be better to have 'default n' here too.

quoted
+       depends on CRC64
quoted
+#include <linux/init.h>
+#include <linux/list.h>
+#include <linux/module.h>
+#include <linux/printk.h>
+#include <linux/fs.h>
+#include <linux/miscdevice.h>
+#include <linux/slab.h>
+#include <linux/uaccess.h>
+#include <linux/async.h>
+#include <linux/delay.h>
+#include <linux/vmalloc.h>
+#include <linux/crc64.h>
Perhaps in order?
Do you mean in alphabet order of header file names ? I will do it in v2
series.
Moreover, either init.h or module.h depending on the Kconfig (here
seems module.h is a right choice).
Sure I will keep module.h in v2 series.
quoted
+struct crc_test_record {
quoted
+
Redundant.
Removed.
quoted
+       char    *name;
+       __le64  data[4];
+       __le64  initval;
+       __le64  expval;
+       int     (*handler)(struct crc_test_record *rec);
+};
+
+static int chk_and_msg(const char *name, __le64 crc, __le64 expval)
+{
+       int ret = 0;
+
+       if (crc == expval) {
+               pr_info("test_crc: %s: PASSED:(0x%016llx, expval 0x%016llx)",
+                       name, crc, expval);
+       } else {
+               pr_err("test_crc: %s: FAILED:(0x%016llx, expval 0x%016llx)",
+                       name, crc, expval);
+               ret = -EINVAL;
+       }
+
+       return ret;
Perhaps collect statistics instead how it's done in many other tests?
Good idea. I will add this in v2 series.
quoted
+}
+
+/* Add your crc test caese here */
caese ?
Fixed.
quoted
+static int test_crc64_le(struct crc_test_record *rec)
+{
+       __le64 crc;
+
+       crc = crc64_le(rec->data, sizeof(rec->data));
+       return chk_and_msg(rec->name, crc, rec->expval);
quoted
+
Redundant.
Fixed.
quoted
+}
quoted
+       { .name = NULL, }
Simple {} would work.
Fixed.
quoted
+static int __init test_crc_init(void)
+{
+       int i;
+       int v, ret = 0;
+
+       pr_info("Kernel crc consitency testing:");
+       for (i = 0; test_data[i].name; i++) {
quoted
+               v = test_data[i].handler(&test_data[i]);
+               if (v < 0 && ret == 0)
+                       ret = -EINVAL;
A bit strange. Anyway, better to collect statistics and print it at
the end with corresponding return code.
Sure, I will add this :-)
quoted
+       }
+
+       return ret;
+}
quoted
+late_initcall(test_crc_init);
Why?
Oh, IMHO this is a test module, we don't need to occupy boot time and it
should be good to invoke it after other modules loaded. As I see many
other test modules do this.
quoted
+static void __exit test_crc_exit(void) { }
+module_exit(test_crc_exit);
quoted
+MODULE_LICENSE("GPL");
It's not the same as in SPDX.
Nice catch, I will change it to MODULE_LICENSE("GPL v2").

Thanks for all your review !

Coly Li
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help