162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */
262306a36Sopenharmony_ci#ifndef RESCTRL_H
362306a36Sopenharmony_ci#define RESCTRL_H
462306a36Sopenharmony_ci#include <stdio.h>
562306a36Sopenharmony_ci#include <math.h>
662306a36Sopenharmony_ci#include <errno.h>
762306a36Sopenharmony_ci#include <sched.h>
862306a36Sopenharmony_ci#include <stdlib.h>
962306a36Sopenharmony_ci#include <unistd.h>
1062306a36Sopenharmony_ci#include <string.h>
1162306a36Sopenharmony_ci#include <signal.h>
1262306a36Sopenharmony_ci#include <dirent.h>
1362306a36Sopenharmony_ci#include <stdbool.h>
1462306a36Sopenharmony_ci#include <sys/stat.h>
1562306a36Sopenharmony_ci#include <sys/ioctl.h>
1662306a36Sopenharmony_ci#include <sys/mount.h>
1762306a36Sopenharmony_ci#include <sys/types.h>
1862306a36Sopenharmony_ci#include <sys/wait.h>
1962306a36Sopenharmony_ci#include <sys/select.h>
2062306a36Sopenharmony_ci#include <sys/time.h>
2162306a36Sopenharmony_ci#include <sys/eventfd.h>
2262306a36Sopenharmony_ci#include <asm/unistd.h>
2362306a36Sopenharmony_ci#include <linux/perf_event.h>
2462306a36Sopenharmony_ci#include "../kselftest.h"
2562306a36Sopenharmony_ci
2662306a36Sopenharmony_ci#define MB			(1024 * 1024)
2762306a36Sopenharmony_ci#define RESCTRL_PATH		"/sys/fs/resctrl"
2862306a36Sopenharmony_ci#define PHYS_ID_PATH		"/sys/devices/system/cpu/cpu"
2962306a36Sopenharmony_ci#define INFO_PATH		"/sys/fs/resctrl/info"
3062306a36Sopenharmony_ci
3162306a36Sopenharmony_ci#define ARCH_INTEL     1
3262306a36Sopenharmony_ci#define ARCH_AMD       2
3362306a36Sopenharmony_ci
3462306a36Sopenharmony_ci#define END_OF_TESTS	1
3562306a36Sopenharmony_ci
3662306a36Sopenharmony_ci#define BENCHMARK_ARGS		64
3762306a36Sopenharmony_ci
3862306a36Sopenharmony_ci#define DEFAULT_SPAN		(250 * MB)
3962306a36Sopenharmony_ci
4062306a36Sopenharmony_ci#define PARENT_EXIT(err_msg)			\
4162306a36Sopenharmony_ci	do {					\
4262306a36Sopenharmony_ci		perror(err_msg);		\
4362306a36Sopenharmony_ci		kill(ppid, SIGKILL);		\
4462306a36Sopenharmony_ci		umount_resctrlfs();		\
4562306a36Sopenharmony_ci		exit(EXIT_FAILURE);		\
4662306a36Sopenharmony_ci	} while (0)
4762306a36Sopenharmony_ci
4862306a36Sopenharmony_ci/*
4962306a36Sopenharmony_ci * resctrl_val_param:	resctrl test parameters
5062306a36Sopenharmony_ci * @resctrl_val:	Resctrl feature (Eg: mbm, mba.. etc)
5162306a36Sopenharmony_ci * @ctrlgrp:		Name of the control monitor group (con_mon grp)
5262306a36Sopenharmony_ci * @mongrp:		Name of the monitor group (mon grp)
5362306a36Sopenharmony_ci * @cpu_no:		CPU number to which the benchmark would be binded
5462306a36Sopenharmony_ci * @filename:		Name of file to which the o/p should be written
5562306a36Sopenharmony_ci * @bw_report:		Bandwidth report type (reads vs writes)
5662306a36Sopenharmony_ci * @setup:		Call back function to setup test environment
5762306a36Sopenharmony_ci */
5862306a36Sopenharmony_cistruct resctrl_val_param {
5962306a36Sopenharmony_ci	char		*resctrl_val;
6062306a36Sopenharmony_ci	char		ctrlgrp[64];
6162306a36Sopenharmony_ci	char		mongrp[64];
6262306a36Sopenharmony_ci	int		cpu_no;
6362306a36Sopenharmony_ci	char		filename[64];
6462306a36Sopenharmony_ci	char		*bw_report;
6562306a36Sopenharmony_ci	unsigned long	mask;
6662306a36Sopenharmony_ci	int		num_of_runs;
6762306a36Sopenharmony_ci	int		(*setup)(struct resctrl_val_param *param);
6862306a36Sopenharmony_ci};
6962306a36Sopenharmony_ci
7062306a36Sopenharmony_ci#define MBM_STR			"mbm"
7162306a36Sopenharmony_ci#define MBA_STR			"mba"
7262306a36Sopenharmony_ci#define CMT_STR			"cmt"
7362306a36Sopenharmony_ci#define CAT_STR			"cat"
7462306a36Sopenharmony_ci
7562306a36Sopenharmony_ciextern pid_t bm_pid, ppid;
7662306a36Sopenharmony_ci
7762306a36Sopenharmony_ciextern char llc_occup_path[1024];
7862306a36Sopenharmony_ci
7962306a36Sopenharmony_ciint get_vendor(void);
8062306a36Sopenharmony_cibool check_resctrlfs_support(void);
8162306a36Sopenharmony_ciint filter_dmesg(void);
8262306a36Sopenharmony_ciint get_resource_id(int cpu_no, int *resource_id);
8362306a36Sopenharmony_ciint mount_resctrlfs(void);
8462306a36Sopenharmony_ciint umount_resctrlfs(void);
8562306a36Sopenharmony_ciint validate_bw_report_request(char *bw_report);
8662306a36Sopenharmony_cibool validate_resctrl_feature_request(const char *resource, const char *feature);
8762306a36Sopenharmony_cichar *fgrep(FILE *inf, const char *str);
8862306a36Sopenharmony_ciint taskset_benchmark(pid_t bm_pid, int cpu_no);
8962306a36Sopenharmony_civoid run_benchmark(int signum, siginfo_t *info, void *ucontext);
9062306a36Sopenharmony_ciint write_schemata(char *ctrlgrp, char *schemata, int cpu_no,
9162306a36Sopenharmony_ci		   char *resctrl_val);
9262306a36Sopenharmony_ciint write_bm_pid_to_resctrl(pid_t bm_pid, char *ctrlgrp, char *mongrp,
9362306a36Sopenharmony_ci			    char *resctrl_val);
9462306a36Sopenharmony_ciint perf_event_open(struct perf_event_attr *hw_event, pid_t pid, int cpu,
9562306a36Sopenharmony_ci		    int group_fd, unsigned long flags);
9662306a36Sopenharmony_ciint run_fill_buf(size_t span, int memflush, int op, bool once);
9762306a36Sopenharmony_ciint resctrl_val(const char * const *benchmark_cmd, struct resctrl_val_param *param);
9862306a36Sopenharmony_ciint mbm_bw_change(int cpu_no, const char * const *benchmark_cmd);
9962306a36Sopenharmony_civoid tests_cleanup(void);
10062306a36Sopenharmony_civoid mbm_test_cleanup(void);
10162306a36Sopenharmony_ciint mba_schemata_change(int cpu_no, const char * const *benchmark_cmd);
10262306a36Sopenharmony_civoid mba_test_cleanup(void);
10362306a36Sopenharmony_ciint get_cbm_mask(char *cache_type, char *cbm_mask);
10462306a36Sopenharmony_ciint get_cache_size(int cpu_no, char *cache_type, unsigned long *cache_size);
10562306a36Sopenharmony_civoid ctrlc_handler(int signum, siginfo_t *info, void *ptr);
10662306a36Sopenharmony_ciint signal_handler_register(void);
10762306a36Sopenharmony_civoid signal_handler_unregister(void);
10862306a36Sopenharmony_ciint cat_val(struct resctrl_val_param *param, size_t span);
10962306a36Sopenharmony_civoid cat_test_cleanup(void);
11062306a36Sopenharmony_ciint cat_perf_miss_val(int cpu_no, int no_of_bits, char *cache_type);
11162306a36Sopenharmony_ciint cmt_resctrl_val(int cpu_no, int n, const char * const *benchmark_cmd);
11262306a36Sopenharmony_ciunsigned int count_bits(unsigned long n);
11362306a36Sopenharmony_civoid cmt_test_cleanup(void);
11462306a36Sopenharmony_ciint get_core_sibling(int cpu_no);
11562306a36Sopenharmony_ciint measure_cache_vals(struct resctrl_val_param *param, int bm_pid);
11662306a36Sopenharmony_ciint show_cache_info(unsigned long sum_llc_val, int no_of_bits,
11762306a36Sopenharmony_ci		    size_t cache_span, unsigned long max_diff,
11862306a36Sopenharmony_ci		    unsigned long max_diff_percent, unsigned long num_of_runs,
11962306a36Sopenharmony_ci		    bool platform, bool cmt);
12062306a36Sopenharmony_ci
12162306a36Sopenharmony_ci#endif /* RESCTRL_H */
122