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