On Fri, 13 Mar 2026, Reinette Chatre wrote:

> The CAT test relies on the PERF_COUNT_HW_CACHE_MISSES event to determine if
> modifying a cache portion size is successful. This event is configured to
> report the data as part of an event group, but no other events are added to
> the group.
> 
> Remove the unnecessary PERF_FORMAT_GROUP format setting. This eliminates
> the need for struct perf_event_read and results in read() of the associated
> file descriptor to return just one value associated with the
> PERF_COUNT_HW_CACHE_MISSES event of interest.
> 
> Signed-off-by: Reinette Chatre <[email protected]>
> Tested-by: Chen Yu <[email protected]>
> ---
> Changes since v2:
> - Add Chen Yu's tag.
> ---
>  tools/testing/selftests/resctrl/cache.c    | 17 +++++------------
>  tools/testing/selftests/resctrl/cat_test.c |  4 +---
>  tools/testing/selftests/resctrl/resctrl.h  | 11 +----------
>  3 files changed, 7 insertions(+), 25 deletions(-)
> 
> diff --git a/tools/testing/selftests/resctrl/cache.c 
> b/tools/testing/selftests/resctrl/cache.c
> index bef71b6feacc..df9bea584a2d 100644
> --- a/tools/testing/selftests/resctrl/cache.c
> +++ b/tools/testing/selftests/resctrl/cache.c
> @@ -10,7 +10,6 @@ void perf_event_attr_initialize(struct perf_event_attr 
> *pea, __u64 config)
>       memset(pea, 0, sizeof(*pea));
>       pea->type = PERF_TYPE_HARDWARE;
>       pea->size = sizeof(*pea);
> -     pea->read_format = PERF_FORMAT_GROUP;
>       pea->exclude_kernel = 1;
>       pea->exclude_hv = 1;
>       pea->exclude_idle = 1;
> @@ -37,19 +36,13 @@ int perf_event_reset_enable(int pe_fd)
>       return 0;
>  }
>  
> -void perf_event_initialize_read_format(struct perf_event_read *pe_read)
> -{
> -     memset(pe_read, 0, sizeof(*pe_read));
> -     pe_read->nr = 1;
> -}
> -
>  int perf_open(struct perf_event_attr *pea, pid_t pid, int cpu_no)
>  {
>       int pe_fd;
>  
>       pe_fd = perf_event_open(pea, pid, cpu_no, -1, PERF_FLAG_FD_CLOEXEC);
>       if (pe_fd == -1) {
> -             ksft_perror("Error opening leader");
> +             ksft_perror("Unable to set up performance monitoring");
>               return -1;
>       }
>  
> @@ -132,9 +125,9 @@ static int print_results_cache(const char *filename, 
> pid_t bm_pid, __u64 llc_val
>   *
>   * Return: =0 on success. <0 on failure.
>   */
> -int perf_event_measure(int pe_fd, struct perf_event_read *pe_read,
> -                    const char *filename, pid_t bm_pid)
> +int perf_event_measure(int pe_fd, const char *filename, pid_t bm_pid)
>  {
> +     __u64 value;
>       int ret;
>  
>       /* Stop counters after one span to get miss rate */
> @@ -142,13 +135,13 @@ int perf_event_measure(int pe_fd, struct 
> perf_event_read *pe_read,
>       if (ret < 0)
>               return ret;
>  
> -     ret = read(pe_fd, pe_read, sizeof(*pe_read));
> +     ret = read(pe_fd, &value, sizeof(value));
>       if (ret == -1) {
>               ksft_perror("Could not get perf value");
>               return -1;
>       }
>  
> -     return print_results_cache(filename, bm_pid, pe_read->values[0].value);
> +     return print_results_cache(filename, bm_pid, value);
>  }
>  
>  /*
> diff --git a/tools/testing/selftests/resctrl/cat_test.c 
> b/tools/testing/selftests/resctrl/cat_test.c
> index 8bc47f06679a..6aac03147d41 100644
> --- a/tools/testing/selftests/resctrl/cat_test.c
> +++ b/tools/testing/selftests/resctrl/cat_test.c
> @@ -135,7 +135,6 @@ static int cat_test(const struct resctrl_test *test,
>                   struct resctrl_val_param *param,
>                   size_t span, unsigned long current_mask)
>  {
> -     struct perf_event_read pe_read;
>       struct perf_event_attr pea;
>       cpu_set_t old_affinity;
>       unsigned char *buf;
> @@ -159,7 +158,6 @@ static int cat_test(const struct resctrl_test *test,
>               goto reset_affinity;
>  
>       perf_event_attr_initialize(&pea, PERF_COUNT_HW_CACHE_MISSES);
> -     perf_event_initialize_read_format(&pe_read);
>       pe_fd = perf_open(&pea, bm_pid, uparams->cpu);
>       if (pe_fd < 0) {
>               ret = -1;
> @@ -192,7 +190,7 @@ static int cat_test(const struct resctrl_test *test,
>  
>                       fill_cache_read(buf, span, true);
>  
> -                     ret = perf_event_measure(pe_fd, &pe_read, 
> param->filename, bm_pid);
> +                     ret = perf_event_measure(pe_fd, param->filename, 
> bm_pid);
>                       if (ret)
>                               goto free_buf;
>               }
> diff --git a/tools/testing/selftests/resctrl/resctrl.h 
> b/tools/testing/selftests/resctrl/resctrl.h
> index 3bad2d80c09b..175101022bf3 100644
> --- a/tools/testing/selftests/resctrl/resctrl.h
> +++ b/tools/testing/selftests/resctrl/resctrl.h
> @@ -148,13 +148,6 @@ struct resctrl_val_param {
>       struct fill_buf_param   *fill_buf;
>  };
>  
> -struct perf_event_read {
> -     __u64 nr;                       /* The number of events */
> -     struct {
> -             __u64 value;            /* The value of the event */
> -     } values[2];
> -};
> -
>  /*
>   * Memory location that consumes values compiler must not optimize away.
>   * Volatile ensures writes to this location cannot be optimized away by
> @@ -210,11 +203,9 @@ unsigned int count_bits(unsigned long n);
>  int snc_kernel_support(void);
>  
>  void perf_event_attr_initialize(struct perf_event_attr *pea, __u64 config);
> -void perf_event_initialize_read_format(struct perf_event_read *pe_read);
>  int perf_open(struct perf_event_attr *pea, pid_t pid, int cpu_no);
>  int perf_event_reset_enable(int pe_fd);
> -int perf_event_measure(int pe_fd, struct perf_event_read *pe_read,
> -                    const char *filename, pid_t bm_pid);
> +int perf_event_measure(int pe_fd, const char *filename, pid_t bm_pid);
>  int measure_llc_resctrl(const char *filename, pid_t bm_pid);
>  int minimize_l2_occupancy(const struct resctrl_test *test,
>                         const struct user_params *uparams,
> 

Reviewed-by: Ilpo Järvinen <[email protected]>


-- 
 i.

Reply via email to