mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 37c3193fa4
			
		
	
	
		37c3193fa4
		
	
	
	
	
		
			
			libperf's verbose printing checks the -v option every time the macro _T_ START is called. Since there are currently four libperf tests registered, the macro _T_ START is called four times, but verbose printing after the second time is not output. Resets the index of the element processed by getopt() and fix verbose printing so that it prints in all tests. Signed-off-by: Shunsuke Nakamura <nakamura.shun@fujitsu.com> Acked-by: Rob Herring <robh@kernel.org> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Jiri Olsa <jolsa@redhat.com> Cc: Mark Rutland <mark.rutland@arm.com> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Peter Zijlstra <peterz@infradead.org> Link: http://lore.kernel.org/lkml/20210820093908.734503-3-nakamura.shun@fujitsu.com Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
		
			
				
	
	
		
			68 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			68 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| #ifndef __LIBPERF_INTERNAL_TESTS_H
 | |
| #define __LIBPERF_INTERNAL_TESTS_H
 | |
| 
 | |
| #include <stdio.h>
 | |
| #include <unistd.h>
 | |
| 
 | |
| extern int tests_failed;
 | |
| extern int tests_verbose;
 | |
| 
 | |
| static inline int get_verbose(char **argv, int argc)
 | |
| {
 | |
| 	int c;
 | |
| 	int verbose = 0;
 | |
| 
 | |
| 	while ((c = getopt(argc, argv, "v")) != -1) {
 | |
| 		switch (c)
 | |
| 		{
 | |
| 		case 'v':
 | |
| 			verbose = 1;
 | |
| 			break;
 | |
| 		default:
 | |
| 			break;
 | |
| 		}
 | |
| 	}
 | |
| 	optind = 1;
 | |
| 
 | |
| 	return verbose;
 | |
| }
 | |
| 
 | |
| #define __T_START					\
 | |
| do {							\
 | |
| 	tests_verbose = get_verbose(argv, argc);	\
 | |
| 	fprintf(stdout, "- running %s...", __FILE__);	\
 | |
| 	fflush(NULL);					\
 | |
| 	tests_failed = 0;				\
 | |
| } while (0)
 | |
| 
 | |
| #define __T_END								\
 | |
| do {									\
 | |
| 	if (tests_failed)						\
 | |
| 		fprintf(stdout, "  FAILED (%d)\n", tests_failed);	\
 | |
| 	else								\
 | |
| 		fprintf(stdout, "OK\n");				\
 | |
| } while (0)
 | |
| 
 | |
| #define __T(text, cond)                                                          \
 | |
| do {                                                                             \
 | |
| 	if (!(cond)) {                                                           \
 | |
| 		fprintf(stderr, "FAILED %s:%d %s\n", __FILE__, __LINE__, text);  \
 | |
| 		tests_failed++;                                                  \
 | |
| 		return -1;                                                       \
 | |
| 	}                                                                        \
 | |
| } while (0)
 | |
| 
 | |
| #define __T_VERBOSE(...)						\
 | |
| do {									\
 | |
| 	if (tests_verbose) {						\
 | |
| 		if (tests_verbose == 1) {				\
 | |
| 			fputc('\n', stderr);				\
 | |
| 			tests_verbose++;				\
 | |
| 		}							\
 | |
| 		fprintf(stderr, ##__VA_ARGS__);				\
 | |
| 	}								\
 | |
| } while (0)
 | |
| 
 | |
| #endif /* __LIBPERF_INTERNAL_TESTS_H */
 |