xref: /openbmc/linux/lib/dhry_run.c (revision 13684e96)
1d5528cc1SGeert Uytterhoeven // SPDX-License-Identifier: GPL-2.0-only
2d5528cc1SGeert Uytterhoeven /*
3d5528cc1SGeert Uytterhoeven  * Dhrystone benchmark test module
4d5528cc1SGeert Uytterhoeven  *
5d5528cc1SGeert Uytterhoeven  * Copyright (C) 2022 Glider bv
6d5528cc1SGeert Uytterhoeven  */
7d5528cc1SGeert Uytterhoeven 
8d5528cc1SGeert Uytterhoeven #include "dhry.h"
9d5528cc1SGeert Uytterhoeven 
10d5528cc1SGeert Uytterhoeven #include <linux/kernel.h>
11d5528cc1SGeert Uytterhoeven #include <linux/module.h>
12d5528cc1SGeert Uytterhoeven #include <linux/moduleparam.h>
13d5528cc1SGeert Uytterhoeven #include <linux/mutex.h>
14d5528cc1SGeert Uytterhoeven #include <linux/smp.h>
15d5528cc1SGeert Uytterhoeven 
16d5528cc1SGeert Uytterhoeven #define DHRY_VAX	1757
17d5528cc1SGeert Uytterhoeven 
18d5528cc1SGeert Uytterhoeven static int dhry_run_set(const char *val, const struct kernel_param *kp);
19d5528cc1SGeert Uytterhoeven static const struct kernel_param_ops run_ops = {
20d5528cc1SGeert Uytterhoeven 	.flags = KERNEL_PARAM_OPS_FL_NOARG,
21d5528cc1SGeert Uytterhoeven 	.set = dhry_run_set,
22d5528cc1SGeert Uytterhoeven };
23d5528cc1SGeert Uytterhoeven static bool dhry_run;
24d5528cc1SGeert Uytterhoeven module_param_cb(run, &run_ops, &dhry_run, 0200);
25d5528cc1SGeert Uytterhoeven MODULE_PARM_DESC(run, "Run the test (default: false)");
26d5528cc1SGeert Uytterhoeven 
27d5528cc1SGeert Uytterhoeven static int iterations = -1;
28d5528cc1SGeert Uytterhoeven module_param(iterations, int, 0644);
29d5528cc1SGeert Uytterhoeven MODULE_PARM_DESC(iterations,
30d5528cc1SGeert Uytterhoeven 		"Number of iterations through the benchmark (default: auto)");
31d5528cc1SGeert Uytterhoeven 
dhry_benchmark(void)32d5528cc1SGeert Uytterhoeven static void dhry_benchmark(void)
33d5528cc1SGeert Uytterhoeven {
34*13684e96SGeert Uytterhoeven 	unsigned int cpu = get_cpu();
35d5528cc1SGeert Uytterhoeven 	int i, n;
36d5528cc1SGeert Uytterhoeven 
37d5528cc1SGeert Uytterhoeven 	if (iterations > 0) {
38d5528cc1SGeert Uytterhoeven 		n = dhry(iterations);
39d5528cc1SGeert Uytterhoeven 		goto report;
40d5528cc1SGeert Uytterhoeven 	}
41d5528cc1SGeert Uytterhoeven 
42d5528cc1SGeert Uytterhoeven 	for (i = DHRY_VAX; i > 0; i <<= 1) {
43d5528cc1SGeert Uytterhoeven 		n = dhry(i);
44d5528cc1SGeert Uytterhoeven 		if (n != -EAGAIN)
45d5528cc1SGeert Uytterhoeven 			break;
46d5528cc1SGeert Uytterhoeven 	}
47d5528cc1SGeert Uytterhoeven 
48d5528cc1SGeert Uytterhoeven report:
49*13684e96SGeert Uytterhoeven 	put_cpu();
50d5528cc1SGeert Uytterhoeven 	if (n >= 0)
51*13684e96SGeert Uytterhoeven 		pr_info("CPU%u: Dhrystones per Second: %d (%d DMIPS)\n", cpu,
52*13684e96SGeert Uytterhoeven 			n, n / DHRY_VAX);
53d5528cc1SGeert Uytterhoeven 	else if (n == -EAGAIN)
54d5528cc1SGeert Uytterhoeven 		pr_err("Please increase the number of iterations\n");
55d5528cc1SGeert Uytterhoeven 	else
56d5528cc1SGeert Uytterhoeven 		pr_err("Dhrystone benchmark failed error %pe\n", ERR_PTR(n));
57d5528cc1SGeert Uytterhoeven }
58d5528cc1SGeert Uytterhoeven 
dhry_run_set(const char * val,const struct kernel_param * kp)59d5528cc1SGeert Uytterhoeven static int dhry_run_set(const char *val, const struct kernel_param *kp)
60d5528cc1SGeert Uytterhoeven {
61d5528cc1SGeert Uytterhoeven 	int ret;
62d5528cc1SGeert Uytterhoeven 
63d5528cc1SGeert Uytterhoeven 	if (val) {
64d5528cc1SGeert Uytterhoeven 		ret = param_set_bool(val, kp);
65d5528cc1SGeert Uytterhoeven 		if (ret)
66d5528cc1SGeert Uytterhoeven 			return ret;
67d5528cc1SGeert Uytterhoeven 	} else {
68d5528cc1SGeert Uytterhoeven 		dhry_run = true;
69d5528cc1SGeert Uytterhoeven 	}
70d5528cc1SGeert Uytterhoeven 
71d5528cc1SGeert Uytterhoeven 	if (dhry_run && system_state == SYSTEM_RUNNING)
72d5528cc1SGeert Uytterhoeven 		dhry_benchmark();
73d5528cc1SGeert Uytterhoeven 
74d5528cc1SGeert Uytterhoeven 	return 0;
75d5528cc1SGeert Uytterhoeven }
76d5528cc1SGeert Uytterhoeven 
dhry_init(void)77d5528cc1SGeert Uytterhoeven static int __init dhry_init(void)
78d5528cc1SGeert Uytterhoeven {
79d5528cc1SGeert Uytterhoeven 	if (dhry_run)
80d5528cc1SGeert Uytterhoeven 		dhry_benchmark();
81d5528cc1SGeert Uytterhoeven 
82d5528cc1SGeert Uytterhoeven 	return 0;
83d5528cc1SGeert Uytterhoeven }
84d5528cc1SGeert Uytterhoeven module_init(dhry_init);
85d5528cc1SGeert Uytterhoeven 
86d5528cc1SGeert Uytterhoeven MODULE_AUTHOR("Geert Uytterhoeven <geert+renesas@glider.be>");
87d5528cc1SGeert Uytterhoeven MODULE_LICENSE("GPL");
88