The kernel perf subsystem has to IPI to the target CPU for many operations. On systems with many CPUs and when managing many events the overhead can be dominated by lots of IPIs. An alternative is to set up CPU affinity in the perf tool, then set up all the events for that CPU, and then move on to the next CPU. Add some affinity management infrastructure to enable such a model. Used in followon patches. Committer notes: Use zfree() in some places, add missing stdbool.h header, some minor coding style changes. Signed-off-by: Andi Kleen <ak@linux.intel.com> Acked-by: Jiri Olsa <jolsa@kernel.org> Link: http://lore.kernel.org/lkml/20191121001522.180827-3-andi@firstfloor.org Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
		
			
				
	
	
		
			18 lines
		
	
	
		
			362 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			18 lines
		
	
	
		
			362 B
		
	
	
	
		
			C
		
	
	
	
	
	
| // SPDX-License-Identifier: GPL-2.0
 | |
| #ifndef PERF_AFFINITY_H
 | |
| #define PERF_AFFINITY_H 1
 | |
| 
 | |
| #include <stdbool.h>
 | |
| 
 | |
| struct affinity {
 | |
| 	unsigned long *orig_cpus;
 | |
| 	unsigned long *sched_cpus;
 | |
| 	bool changed;
 | |
| };
 | |
| 
 | |
| void affinity__cleanup(struct affinity *a);
 | |
| void affinity__set(struct affinity *a, int cpu);
 | |
| int affinity__setup(struct affinity *a);
 | |
| 
 | |
| #endif // PERF_AFFINITY_H
 |