public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
From: "Ilpo Järvinen" <ilpo.jarvinen@linux.intel.com>
To: Reinette Chatre <reinette.chatre@intel.com>
Cc: fenghua.yu@intel.com, shuah@kernel.org, tony.luck@intel.com,
	peternewman@google.com, babu.moger@amd.com,
	"Maciej Wieczór-Retman" <maciej.wieczor-retman@intel.com>,
	linux-kselftest@vger.kernel.org,
	LKML <linux-kernel@vger.kernel.org>
Subject: Re: [PATCH V2 08/13] selftests/resctrl: Remove unused measurement code
Date: Mon, 30 Sep 2024 16:59:10 +0300 (EEST)	[thread overview]
Message-ID: <5fa3b9e8-66d4-56f6-15c1-4c71bb68652c@linux.intel.com> (raw)
In-Reply-To: <a6ef99e70387dcc3ff67cda0548da250e4920e40.1726164080.git.reinette.chatre@intel.com>

[-- Attachment #1: Type: text/plain, Size: 21438 bytes --]

On Thu, 12 Sep 2024, Reinette Chatre wrote:

> The MBM and MBA resctrl selftests run a benchmark during which
> it takes measurements of read memory bandwidth via perf.
> Code exists to support measurements of write memory bandwidth
> but there exists no path with which this code can execute.
> 
> While code exists for write memory bandwidth measurement
> there has not yet been a use case for it. Remove this unused code.
> Rename relevant functions to include "read" so that it is clear
> that it relates only to memory bandwidth reads, while renaming
> the functions also add consistency by changing the "membw"
> instances to more prevalent "mem_bw".
> 
> Signed-off-by: Reinette Chatre <reinette.chatre@intel.com>

Reviewed-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>

I'll take a look at the rest of the series later.

-- 
 i.

> ---
> Changes since V1:
> - New patch.
> ---
>  tools/testing/selftests/resctrl/mba_test.c    |   4 +-
>  tools/testing/selftests/resctrl/mbm_test.c    |   4 +-
>  tools/testing/selftests/resctrl/resctrl.h     |   8 +-
>  tools/testing/selftests/resctrl/resctrl_val.c | 234 ++++++------------
>  tools/testing/selftests/resctrl/resctrlfs.c   |  17 --
>  5 files changed, 85 insertions(+), 182 deletions(-)
> 
> diff --git a/tools/testing/selftests/resctrl/mba_test.c b/tools/testing/selftests/resctrl/mba_test.c
> index da40a8ed4413..be0ead73e55d 100644
> --- a/tools/testing/selftests/resctrl/mba_test.c
> +++ b/tools/testing/selftests/resctrl/mba_test.c
> @@ -21,7 +21,7 @@ static int mba_init(const struct resctrl_val_param *param, int domain_id)
>  {
>  	int ret;
>  
> -	ret = initialize_mem_bw_imc();
> +	ret = initialize_read_mem_bw_imc();
>  	if (ret)
>  		return ret;
>  
> @@ -68,7 +68,7 @@ static int mba_setup(const struct resctrl_test *test,
>  static int mba_measure(const struct user_params *uparams,
>  		       struct resctrl_val_param *param, pid_t bm_pid)
>  {
> -	return measure_mem_bw(uparams, param, bm_pid, "reads");
> +	return measure_read_mem_bw(uparams, param, bm_pid);
>  }
>  
>  static bool show_mba_info(unsigned long *bw_imc, unsigned long *bw_resc)
> diff --git a/tools/testing/selftests/resctrl/mbm_test.c b/tools/testing/selftests/resctrl/mbm_test.c
> index 80c7a1bc13b8..9744bf1ac16f 100644
> --- a/tools/testing/selftests/resctrl/mbm_test.c
> +++ b/tools/testing/selftests/resctrl/mbm_test.c
> @@ -91,7 +91,7 @@ static int mbm_init(const struct resctrl_val_param *param, int domain_id)
>  {
>  	int ret;
>  
> -	ret = initialize_mem_bw_imc();
> +	ret = initialize_read_mem_bw_imc();
>  	if (ret)
>  		return ret;
>  
> @@ -122,7 +122,7 @@ static int mbm_setup(const struct resctrl_test *test,
>  static int mbm_measure(const struct user_params *uparams,
>  		       struct resctrl_val_param *param, pid_t bm_pid)
>  {
> -	return measure_mem_bw(uparams, param, bm_pid, "reads");
> +	return measure_read_mem_bw(uparams, param, bm_pid);
>  }
>  
>  static void mbm_test_cleanup(void)
> diff --git a/tools/testing/selftests/resctrl/resctrl.h b/tools/testing/selftests/resctrl/resctrl.h
> index ba1ce1b35699..82801245e4c1 100644
> --- a/tools/testing/selftests/resctrl/resctrl.h
> +++ b/tools/testing/selftests/resctrl/resctrl.h
> @@ -126,7 +126,6 @@ int filter_dmesg(void);
>  int get_domain_id(const char *resource, int cpu_no, int *domain_id);
>  int mount_resctrlfs(void);
>  int umount_resctrlfs(void);
> -const char *get_bw_report_type(const char *bw_report);
>  bool resctrl_resource_exists(const char *resource);
>  bool resctrl_mon_feature_exists(const char *resource, const char *feature);
>  bool resource_info_file_exists(const char *resource, const char *file);
> @@ -143,10 +142,9 @@ unsigned char *alloc_buffer(size_t buf_size, int memflush);
>  void mem_flush(unsigned char *buf, size_t buf_size);
>  void fill_cache_read(unsigned char *buf, size_t buf_size, bool once);
>  int run_fill_buf(size_t buf_size, int memflush);
> -int initialize_mem_bw_imc(void);
> -int measure_mem_bw(const struct user_params *uparams,
> -		   struct resctrl_val_param *param, pid_t bm_pid,
> -		   const char *bw_report);
> +int initialize_read_mem_bw_imc(void);
> +int measure_read_mem_bw(const struct user_params *uparams,
> +			struct resctrl_val_param *param, pid_t bm_pid);
>  void initialize_mem_bw_resctrl(const struct resctrl_val_param *param,
>  			       int domain_id);
>  int resctrl_val(const struct resctrl_test *test,
> diff --git a/tools/testing/selftests/resctrl/resctrl_val.c b/tools/testing/selftests/resctrl/resctrl_val.c
> index 8b5973c5e934..a1e097dc8e05 100644
> --- a/tools/testing/selftests/resctrl/resctrl_val.c
> +++ b/tools/testing/selftests/resctrl/resctrl_val.c
> @@ -12,13 +12,10 @@
>  
>  #define UNCORE_IMC		"uncore_imc"
>  #define READ_FILE_NAME		"events/cas_count_read"
> -#define WRITE_FILE_NAME		"events/cas_count_write"
>  #define DYN_PMU_PATH		"/sys/bus/event_source/devices"
>  #define SCALE			0.00006103515625
>  #define MAX_IMCS		20
>  #define MAX_TOKENS		5
> -#define READ			0
> -#define WRITE			1
>  
>  #define CON_MBM_LOCAL_BYTES_PATH		\
>  	"%s/%s/mon_data/mon_L3_%02d/mbm_local_bytes"
> @@ -41,44 +38,43 @@ struct imc_counter_config {
>  
>  static char mbm_total_path[1024];
>  static int imcs;
> -static struct imc_counter_config imc_counters_config[MAX_IMCS][2];
> +static struct imc_counter_config imc_counters_config[MAX_IMCS];
>  static const struct resctrl_test *current_test;
>  
> -static void membw_initialize_perf_event_attr(int i, int j)
> +static void read_mem_bw_initialize_perf_event_attr(int i)
>  {
> -	memset(&imc_counters_config[i][j].pe, 0,
> +	memset(&imc_counters_config[i].pe, 0,
>  	       sizeof(struct perf_event_attr));
> -	imc_counters_config[i][j].pe.type = imc_counters_config[i][j].type;
> -	imc_counters_config[i][j].pe.size = sizeof(struct perf_event_attr);
> -	imc_counters_config[i][j].pe.disabled = 1;
> -	imc_counters_config[i][j].pe.inherit = 1;
> -	imc_counters_config[i][j].pe.exclude_guest = 0;
> -	imc_counters_config[i][j].pe.config =
> -		imc_counters_config[i][j].umask << 8 |
> -		imc_counters_config[i][j].event;
> -	imc_counters_config[i][j].pe.sample_type = PERF_SAMPLE_IDENTIFIER;
> -	imc_counters_config[i][j].pe.read_format =
> +	imc_counters_config[i].pe.type = imc_counters_config[i].type;
> +	imc_counters_config[i].pe.size = sizeof(struct perf_event_attr);
> +	imc_counters_config[i].pe.disabled = 1;
> +	imc_counters_config[i].pe.inherit = 1;
> +	imc_counters_config[i].pe.exclude_guest = 0;
> +	imc_counters_config[i].pe.config =
> +		imc_counters_config[i].umask << 8 |
> +		imc_counters_config[i].event;
> +	imc_counters_config[i].pe.sample_type = PERF_SAMPLE_IDENTIFIER;
> +	imc_counters_config[i].pe.read_format =
>  		PERF_FORMAT_TOTAL_TIME_ENABLED | PERF_FORMAT_TOTAL_TIME_RUNNING;
>  }
>  
> -static void membw_ioctl_perf_event_ioc_reset_enable(int i, int j)
> +static void read_mem_bw_ioctl_perf_event_ioc_reset_enable(int i)
>  {
> -	ioctl(imc_counters_config[i][j].fd, PERF_EVENT_IOC_RESET, 0);
> -	ioctl(imc_counters_config[i][j].fd, PERF_EVENT_IOC_ENABLE, 0);
> +	ioctl(imc_counters_config[i].fd, PERF_EVENT_IOC_RESET, 0);
> +	ioctl(imc_counters_config[i].fd, PERF_EVENT_IOC_ENABLE, 0);
>  }
>  
> -static void membw_ioctl_perf_event_ioc_disable(int i, int j)
> +static void read_mem_bw_ioctl_perf_event_ioc_disable(int i)
>  {
> -	ioctl(imc_counters_config[i][j].fd, PERF_EVENT_IOC_DISABLE, 0);
> +	ioctl(imc_counters_config[i].fd, PERF_EVENT_IOC_DISABLE, 0);
>  }
>  
>  /*
> - * get_event_and_umask:	Parse config into event and umask
> + * get_read_event_and_umask:	Parse config into event and umask
>   * @cas_count_cfg:	Config
>   * @count:		iMC number
> - * @op:			Operation (read/write)
>   */
> -static void get_event_and_umask(char *cas_count_cfg, int count, bool op)
> +static void get_read_event_and_umask(char *cas_count_cfg, int count)
>  {
>  	char *token[MAX_TOKENS];
>  	int i = 0;
> @@ -91,34 +87,22 @@ static void get_event_and_umask(char *cas_count_cfg, int count, bool op)
>  	for (i = 0; i < MAX_TOKENS - 1; i++) {
>  		if (!token[i])
>  			break;
> -		if (strcmp(token[i], "event") == 0) {
> -			if (op == READ)
> -				imc_counters_config[count][READ].event =
> -				strtol(token[i + 1], NULL, 16);
> -			else
> -				imc_counters_config[count][WRITE].event =
> -				strtol(token[i + 1], NULL, 16);
> -		}
> -		if (strcmp(token[i], "umask") == 0) {
> -			if (op == READ)
> -				imc_counters_config[count][READ].umask =
> -				strtol(token[i + 1], NULL, 16);
> -			else
> -				imc_counters_config[count][WRITE].umask =
> -				strtol(token[i + 1], NULL, 16);
> -		}
> +		if (strcmp(token[i], "event") == 0)
> +			imc_counters_config[count].event = strtol(token[i + 1], NULL, 16);
> +		if (strcmp(token[i], "umask") == 0)
> +			imc_counters_config[count].umask = strtol(token[i + 1], NULL, 16);
>  	}
>  }
>  
> -static int open_perf_event(int i, int cpu_no, int j)
> +static int open_perf_read_event(int i, int cpu_no)
>  {
> -	imc_counters_config[i][j].fd =
> -		perf_event_open(&imc_counters_config[i][j].pe, -1, cpu_no, -1,
> +	imc_counters_config[i].fd =
> +		perf_event_open(&imc_counters_config[i].pe, -1, cpu_no, -1,
>  				PERF_FLAG_FD_CLOEXEC);
>  
> -	if (imc_counters_config[i][j].fd == -1) {
> +	if (imc_counters_config[i].fd == -1) {
>  		fprintf(stderr, "Error opening leader %llx\n",
> -			imc_counters_config[i][j].pe.config);
> +			imc_counters_config[i].pe.config);
>  
>  		return -1;
>  	}
> @@ -126,7 +110,7 @@ static int open_perf_event(int i, int cpu_no, int j)
>  	return 0;
>  }
>  
> -/* Get type and config (read and write) of an iMC counter */
> +/* Get type and config of an iMC counter's read event. */
>  static int read_from_imc_dir(char *imc_dir, int count)
>  {
>  	char cas_count_cfg[1024], imc_counter_cfg[1024], imc_counter_type[1024];
> @@ -140,7 +124,7 @@ static int read_from_imc_dir(char *imc_dir, int count)
>  
>  		return -1;
>  	}
> -	if (fscanf(fp, "%u", &imc_counters_config[count][READ].type) <= 0) {
> +	if (fscanf(fp, "%u", &imc_counters_config[count].type) <= 0) {
>  		ksft_perror("Could not get iMC type");
>  		fclose(fp);
>  
> @@ -148,9 +132,6 @@ static int read_from_imc_dir(char *imc_dir, int count)
>  	}
>  	fclose(fp);
>  
> -	imc_counters_config[count][WRITE].type =
> -				imc_counters_config[count][READ].type;
> -
>  	/* Get read config */
>  	sprintf(imc_counter_cfg, "%s%s", imc_dir, READ_FILE_NAME);
>  	fp = fopen(imc_counter_cfg, "r");
> @@ -167,34 +148,19 @@ static int read_from_imc_dir(char *imc_dir, int count)
>  	}
>  	fclose(fp);
>  
> -	get_event_and_umask(cas_count_cfg, count, READ);
> -
> -	/* Get write config */
> -	sprintf(imc_counter_cfg, "%s%s", imc_dir, WRITE_FILE_NAME);
> -	fp = fopen(imc_counter_cfg, "r");
> -	if (!fp) {
> -		ksft_perror("Failed to open iMC config file");
> -
> -		return -1;
> -	}
> -	if  (fscanf(fp, "%s", cas_count_cfg) <= 0) {
> -		ksft_perror("Could not get iMC cas count write");
> -		fclose(fp);
> -
> -		return -1;
> -	}
> -	fclose(fp);
> -
> -	get_event_and_umask(cas_count_cfg, count, WRITE);
> +	get_read_event_and_umask(cas_count_cfg, count);
>  
>  	return 0;
>  }
>  
>  /*
>   * A system can have 'n' number of iMC (Integrated Memory Controller)
> - * counters, get that 'n'. For each iMC counter get it's type and config.
> - * Also, each counter has two configs, one for read and the other for write.
> - * A config again has two parts, event and umask.
> + * counters, get that 'n'. Discover the properties of the available
> + * counters in support of needed performance measurement via perf.
> + * For each iMC counter get it's type and config. Also obtain each
> + * counter's event and umask for the memory read events that will be
> + * measured.
> + *
>   * Enumerate all these details into an array of structures.
>   *
>   * Return: >= 0 on success. < 0 on failure.
> @@ -255,55 +221,46 @@ static int num_of_imcs(void)
>  	return count;
>  }
>  
> -int initialize_mem_bw_imc(void)
> +int initialize_read_mem_bw_imc(void)
>  {
> -	int imc, j;
> +	int imc;
>  
>  	imcs = num_of_imcs();
>  	if (imcs <= 0)
>  		return imcs;
>  
>  	/* Initialize perf_event_attr structures for all iMC's */
> -	for (imc = 0; imc < imcs; imc++) {
> -		for (j = 0; j < 2; j++)
> -			membw_initialize_perf_event_attr(imc, j);
> -	}
> +	for (imc = 0; imc < imcs; imc++)
> +		read_mem_bw_initialize_perf_event_attr(imc);
>  
>  	return 0;
>  }
>  
> -static void perf_close_imc_mem_bw(void)
> +static void perf_close_imc_read_mem_bw(void)
>  {
>  	int mc;
>  
>  	for (mc = 0; mc < imcs; mc++) {
> -		if (imc_counters_config[mc][READ].fd != -1)
> -			close(imc_counters_config[mc][READ].fd);
> -		if (imc_counters_config[mc][WRITE].fd != -1)
> -			close(imc_counters_config[mc][WRITE].fd);
> +		if (imc_counters_config[mc].fd != -1)
> +			close(imc_counters_config[mc].fd);
>  	}
>  }
>  
>  /*
> - * perf_open_imc_mem_bw - Open perf fds for IMCs
> + * perf_open_imc_read_mem_bw - Open perf fds for IMCs
>   * @cpu_no: CPU number that the benchmark PID is bound to
>   *
>   * Return: = 0 on success. < 0 on failure.
>   */
> -static int perf_open_imc_mem_bw(int cpu_no)
> +static int perf_open_imc_read_mem_bw(int cpu_no)
>  {
>  	int imc, ret;
>  
> -	for (imc = 0; imc < imcs; imc++) {
> -		imc_counters_config[imc][READ].fd = -1;
> -		imc_counters_config[imc][WRITE].fd = -1;
> -	}
> +	for (imc = 0; imc < imcs; imc++)
> +		imc_counters_config[imc].fd = -1;
>  
>  	for (imc = 0; imc < imcs; imc++) {
> -		ret = open_perf_event(imc, cpu_no, READ);
> -		if (ret)
> -			goto close_fds;
> -		ret = open_perf_event(imc, cpu_no, WRITE);
> +		ret = open_perf_read_event(imc, cpu_no);
>  		if (ret)
>  			goto close_fds;
>  	}
> @@ -311,60 +268,52 @@ static int perf_open_imc_mem_bw(int cpu_no)
>  	return 0;
>  
>  close_fds:
> -	perf_close_imc_mem_bw();
> +	perf_close_imc_read_mem_bw();
>  	return -1;
>  }
>  
>  /*
> - * do_mem_bw_test - Perform memory bandwidth test
> + * do_imc_read_mem_bw_test - Perform memory bandwidth test
>   *
>   * Runs memory bandwidth test over one second period. Also, handles starting
>   * and stopping of the IMC perf counters around the test.
>   */
> -static void do_imc_mem_bw_test(void)
> +static void do_imc_read_mem_bw_test(void)
>  {
>  	int imc;
>  
> -	for (imc = 0; imc < imcs; imc++) {
> -		membw_ioctl_perf_event_ioc_reset_enable(imc, READ);
> -		membw_ioctl_perf_event_ioc_reset_enable(imc, WRITE);
> -	}
> +	for (imc = 0; imc < imcs; imc++)
> +		read_mem_bw_ioctl_perf_event_ioc_reset_enable(imc);
>  
>  	sleep(1);
>  
> -	/* Stop counters after a second to get results (both read and write) */
> -	for (imc = 0; imc < imcs; imc++) {
> -		membw_ioctl_perf_event_ioc_disable(imc, READ);
> -		membw_ioctl_perf_event_ioc_disable(imc, WRITE);
> -	}
> +	/* Stop counters after a second to get results. */
> +	for (imc = 0; imc < imcs; imc++)
> +		read_mem_bw_ioctl_perf_event_ioc_disable(imc);
>  }
>  
>  /*
> - * get_mem_bw_imc - Memory bandwidth as reported by iMC counters
> - * @bw_report: Bandwidth report type (reads, writes)
> + * get_read_mem_bw_imc - Memory read bandwidth as reported by iMC counters
>   *
> - * Memory bandwidth utilized by a process on a socket can be calculated
> - * using iMC counters. Perf events are used to read these counters.
> + * Memory read bandwidth utilized by a process on a socket can be calculated
> + * using iMC counters' read events. Perf events are used to read these
> + * counters.
>   *
>   * Return: = 0 on success. < 0 on failure.
>   */
> -static int get_mem_bw_imc(const char *bw_report, float *bw_imc)
> +static int get_read_mem_bw_imc(float *bw_imc)
>  {
> -	float reads, writes, of_mul_read, of_mul_write;
> +	float reads = 0, of_mul_read = 1;
>  	int imc;
>  
> -	/* Start all iMC counters to log values (both read and write) */
> -	reads = 0, writes = 0, of_mul_read = 1, of_mul_write = 1;
> -
>  	/*
> -	 * Get results which are stored in struct type imc_counter_config
> +	 * Log read event values from all iMC counters into
> +	 * struct imc_counter_config.
>  	 * Take overflow into consideration before calculating total bandwidth.
>  	 */
>  	for (imc = 0; imc < imcs; imc++) {
>  		struct imc_counter_config *r =
> -			&imc_counters_config[imc][READ];
> -		struct imc_counter_config *w =
> -			&imc_counters_config[imc][WRITE];
> +			&imc_counters_config[imc];
>  
>  		if (read(r->fd, &r->return_value,
>  			 sizeof(struct membw_read_format)) == -1) {
> @@ -372,12 +321,6 @@ static int get_mem_bw_imc(const char *bw_report, float *bw_imc)
>  			return -1;
>  		}
>  
> -		if (read(w->fd, &w->return_value,
> -			 sizeof(struct membw_read_format)) == -1) {
> -			ksft_perror("Couldn't get write bandwidth through iMC");
> -			return -1;
> -		}
> -
>  		__u64 r_time_enabled = r->return_value.time_enabled;
>  		__u64 r_time_running = r->return_value.time_running;
>  
> @@ -385,27 +328,10 @@ static int get_mem_bw_imc(const char *bw_report, float *bw_imc)
>  			of_mul_read = (float)r_time_enabled /
>  					(float)r_time_running;
>  
> -		__u64 w_time_enabled = w->return_value.time_enabled;
> -		__u64 w_time_running = w->return_value.time_running;
> -
> -		if (w_time_enabled != w_time_running)
> -			of_mul_write = (float)w_time_enabled /
> -					(float)w_time_running;
>  		reads += r->return_value.value * of_mul_read * SCALE;
> -		writes += w->return_value.value * of_mul_write * SCALE;
>  	}
>  
> -	if (strcmp(bw_report, "reads") == 0) {
> -		*bw_imc = reads;
> -		return 0;
> -	}
> -
> -	if (strcmp(bw_report, "writes") == 0) {
> -		*bw_imc = writes;
> -		return 0;
> -	}
> -
> -	*bw_imc = reads + writes;
> +	*bw_imc = reads;
>  	return 0;
>  }
>  
> @@ -551,35 +477,31 @@ static int print_results_bw(char *filename, pid_t bm_pid, float bw_imc,
>  }
>  
>  /*
> - * measure_mem_bw - Measures memory bandwidth numbers while benchmark runs
> + * measure_read_mem_bw - Measures read memory bandwidth numbers while benchmark runs
>   * @uparams:		User supplied parameters
>   * @param:		Parameters passed to resctrl_val()
>   * @bm_pid:		PID that runs the benchmark
> - * @bw_report:		Bandwidth report type (reads, writes)
>   *
>   * Measure memory bandwidth from resctrl and from another source which is
>   * perf imc value or could be something else if perf imc event is not
>   * available. Compare the two values to validate resctrl value. It takes
>   * 1 sec to measure the data.
> + * resctrl does not distinguish between read and write operations so
> + * its data includes all memory operations.
>   */
> -int measure_mem_bw(const struct user_params *uparams,
> -		   struct resctrl_val_param *param, pid_t bm_pid,
> -		   const char *bw_report)
> +int measure_read_mem_bw(const struct user_params *uparams,
> +			struct resctrl_val_param *param, pid_t bm_pid)
>  {
>  	unsigned long bw_resc, bw_resc_start, bw_resc_end;
>  	FILE *mem_bw_fp;
>  	float bw_imc;
>  	int ret;
>  
> -	bw_report = get_bw_report_type(bw_report);
> -	if (!bw_report)
> -		return -1;
> -
>  	mem_bw_fp = open_mem_bw_resctrl(mbm_total_path);
>  	if (!mem_bw_fp)
>  		return -1;
>  
> -	ret = perf_open_imc_mem_bw(uparams->cpu);
> +	ret = perf_open_imc_read_mem_bw(uparams->cpu);
>  	if (ret < 0)
>  		goto close_fp;
>  
> @@ -589,17 +511,17 @@ int measure_mem_bw(const struct user_params *uparams,
>  
>  	rewind(mem_bw_fp);
>  
> -	do_imc_mem_bw_test();
> +	do_imc_read_mem_bw_test();
>  
>  	ret = get_mem_bw_resctrl(mem_bw_fp, &bw_resc_end);
>  	if (ret < 0)
>  		goto close_imc;
>  
> -	ret = get_mem_bw_imc(bw_report, &bw_imc);
> +	ret = get_read_mem_bw_imc(&bw_imc);
>  	if (ret < 0)
>  		goto close_imc;
>  
> -	perf_close_imc_mem_bw();
> +	perf_close_imc_read_mem_bw();
>  	fclose(mem_bw_fp);
>  
>  	bw_resc = (bw_resc_end - bw_resc_start) / MB;
> @@ -607,7 +529,7 @@ int measure_mem_bw(const struct user_params *uparams,
>  	return print_results_bw(param->filename, bm_pid, bw_imc, bw_resc);
>  
>  close_imc:
> -	perf_close_imc_mem_bw();
> +	perf_close_imc_read_mem_bw();
>  close_fp:
>  	fclose(mem_bw_fp);
>  	return ret;
> diff --git a/tools/testing/selftests/resctrl/resctrlfs.c b/tools/testing/selftests/resctrl/resctrlfs.c
> index 250c320349a7..eabdf0c20566 100644
> --- a/tools/testing/selftests/resctrl/resctrlfs.c
> +++ b/tools/testing/selftests/resctrl/resctrlfs.c
> @@ -831,23 +831,6 @@ int filter_dmesg(void)
>  	return 0;
>  }
>  
> -const char *get_bw_report_type(const char *bw_report)
> -{
> -	if (strcmp(bw_report, "reads") == 0)
> -		return bw_report;
> -	if (strcmp(bw_report, "writes") == 0)
> -		return bw_report;
> -	if (strcmp(bw_report, "nt-writes") == 0) {
> -		return "writes";
> -	}
> -	if (strcmp(bw_report, "total") == 0)
> -		return bw_report;
> -
> -	fprintf(stderr, "Requested iMC bandwidth report type unavailable\n");
> -
> -	return NULL;
> -}
> -
>  int perf_event_open(struct perf_event_attr *hw_event, pid_t pid, int cpu,
>  		    int group_fd, unsigned long flags)
>  {
> 

  reply	other threads:[~2024-09-30 13:59 UTC|newest]

Thread overview: 30+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2024-09-12 18:13 [PATCH V2 00/13] selftests/resctrl: Support diverse platforms with MBM and MBA tests Reinette Chatre
2024-09-12 18:13 ` [PATCH V2 01/13] selftests/resctrl: Make functions only used in same file static Reinette Chatre
2024-09-12 18:13 ` [PATCH V2 02/13] selftests/resctrl: Print accurate buffer size as part of MBM results Reinette Chatre
2024-09-12 18:13 ` [PATCH V2 03/13] selftests/resctrl: Fix memory overflow due to unhandled wraparound Reinette Chatre
2024-09-30 13:16   ` Ilpo Järvinen
2024-09-12 18:13 ` [PATCH V2 04/13] selftests/resctrl: Protect against array overrun during iMC config parsing Reinette Chatre
2024-09-30 13:35   ` Ilpo Järvinen
2024-09-30 16:04     ` Reinette Chatre
2024-09-12 18:13 ` [PATCH V2 05/13] selftests/resctrl: Make wraparound handling obvious Reinette Chatre
2024-09-12 18:13 ` [PATCH V2 06/13] selftests/resctrl: Remove "once" parameter required to be false Reinette Chatre
2024-09-30 13:49   ` Ilpo Järvinen
2024-09-30 16:07     ` Reinette Chatre
2024-09-12 18:13 ` [PATCH V2 07/13] selftests/resctrl: Only support measured read operation Reinette Chatre
2024-09-30 13:52   ` Ilpo Järvinen
2024-09-30 16:05     ` Reinette Chatre
2024-09-12 18:13 ` [PATCH V2 08/13] selftests/resctrl: Remove unused measurement code Reinette Chatre
2024-09-30 13:59   ` Ilpo Järvinen [this message]
2024-09-12 18:13 ` [PATCH V2 09/13] selftests/resctrl: Make benchmark parameter passing robust Reinette Chatre
2024-10-04 14:05   ` Ilpo Järvinen
2024-10-04 22:21     ` Reinette Chatre
2024-09-12 18:13 ` [PATCH V2 10/13] selftests/resctrl: Ensure measurements skip initialization of default benchmark Reinette Chatre
2024-10-04 14:11   ` Ilpo Järvinen
2024-09-12 18:14 ` [PATCH V2 11/13] selftests/resctrl: Use cache size to determine "fill_buf" buffer size Reinette Chatre
2024-10-04 14:20   ` Ilpo Järvinen
2024-10-04 22:23     ` Reinette Chatre
2024-09-12 18:14 ` [PATCH V2 12/13] selftests/resctrl: Do not compare performance counters and resctrl at low bandwidth Reinette Chatre
2024-10-04 14:23   ` Ilpo Järvinen
2024-09-12 18:14 ` [PATCH V2 13/13] selftests/resctrl: Keep results from first test run Reinette Chatre
2024-10-04 14:29   ` Ilpo Järvinen
2024-10-04 22:24     ` Reinette Chatre

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=5fa3b9e8-66d4-56f6-15c1-4c71bb68652c@linux.intel.com \
    --to=ilpo.jarvinen@linux.intel.com \
    --cc=babu.moger@amd.com \
    --cc=fenghua.yu@intel.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-kselftest@vger.kernel.org \
    --cc=maciej.wieczor-retman@intel.com \
    --cc=peternewman@google.com \
    --cc=reinette.chatre@intel.com \
    --cc=shuah@kernel.org \
    --cc=tony.luck@intel.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox