mirror of
				https://github.com/tiagovignatti/intel-gpu-tools.git
				synced 2025-11-04 12:07:12 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			65 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			65 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
#ifndef I915_PERF_H
 | 
						|
#define I915_PERF_H
 | 
						|
 | 
						|
#include <linux/perf_event.h>
 | 
						|
 | 
						|
#define I915_SAMPLE_BUSY	0
 | 
						|
#define I915_SAMPLE_WAIT	1
 | 
						|
#define I915_SAMPLE_SEMA	2
 | 
						|
 | 
						|
#define I915_SAMPLE_RCS		0
 | 
						|
#define I915_SAMPLE_VCS		1
 | 
						|
#define I915_SAMPLE_BCS		2
 | 
						|
#define I915_SAMPLE_VECS	3
 | 
						|
 | 
						|
#define __I915_PERF_COUNT(ring, id) ((ring) << 4 | (id))
 | 
						|
 | 
						|
#define I915_PERF_COUNT_RCS_BUSY __I915_PERF_COUNT(I915_SAMPLE_RCS, I915_SAMPLE_BUSY)
 | 
						|
#define I915_PERF_COUNT_RCS_WAIT __I915_PERF_COUNT(I915_SAMPLE_RCS, I915_SAMPLE_WAIT)
 | 
						|
#define I915_PERF_COUNT_RCS_SEMA __I915_PERF_COUNT(I915_SAMPLE_RCS, I915_SAMPLE_SEMA)
 | 
						|
 | 
						|
#define I915_PERF_COUNT_VCS_BUSY __I915_PERF_COUNT(I915_SAMPLE_VCS, I915_SAMPLE_BUSY)
 | 
						|
#define I915_PERF_COUNT_VCS_WAIT __I915_PERF_COUNT(I915_SAMPLE_VCS, I915_SAMPLE_WAIT)
 | 
						|
#define I915_PERF_COUNT_VCS_SEMA __I915_PERF_COUNT(I915_SAMPLE_VCS, I915_SAMPLE_SEMA)
 | 
						|
 | 
						|
#define I915_PERF_COUNT_BCS_BUSY __I915_PERF_COUNT(I915_SAMPLE_BCS, I915_SAMPLE_BUSY)
 | 
						|
#define I915_PERF_COUNT_BCS_WAIT __I915_PERF_COUNT(I915_SAMPLE_BCS, I915_SAMPLE_WAIT)
 | 
						|
#define I915_PERF_COUNT_BCS_SEMA __I915_PERF_COUNT(I915_SAMPLE_BCS, I915_SAMPLE_SEMA)
 | 
						|
 | 
						|
#define I915_PERF_COUNT_VECS_BUSY __I915_PERF_COUNT(I915_SAMPLE_VECS, I915_SAMPLE_BUSY)
 | 
						|
#define I915_PERF_COUNT_VECS_WAIT __I915_PERF_COUNT(I915_SAMPLE_VECS, I915_SAMPLE_WAIT)
 | 
						|
#define I915_PERF_COUNT_VECS_SEMA __I915_PERF_COUNT(I915_SAMPLE_VECS, I915_SAMPLE_SEMA)
 | 
						|
 | 
						|
#define I915_PERF_ACTUAL_FREQUENCY 32
 | 
						|
#define I915_PERF_REQUESTED_FREQUENCY 33
 | 
						|
#define I915_PERF_ENERGY 34
 | 
						|
#define I915_PERF_INTERRUPTS 35
 | 
						|
 | 
						|
#define I915_PERF_RC6_RESIDENCY		40
 | 
						|
#define I915_PERF_RC6p_RESIDENCY	41
 | 
						|
#define I915_PERF_RC6pp_RESIDENCY	42
 | 
						|
 | 
						|
static inline int
 | 
						|
perf_event_open(struct perf_event_attr *attr,
 | 
						|
		pid_t pid,
 | 
						|
		int cpu,
 | 
						|
		int group_fd,
 | 
						|
		unsigned long flags)
 | 
						|
{
 | 
						|
#ifndef __NR_perf_event_open
 | 
						|
#if defined(__i386__)
 | 
						|
#define __NR_perf_event_open 336
 | 
						|
#elif defined(__x86_64__)
 | 
						|
#define __NR_perf_event_open 298
 | 
						|
#else
 | 
						|
#define __NR_perf_event_open 0
 | 
						|
#endif
 | 
						|
#endif
 | 
						|
    attr->size = sizeof(*attr);
 | 
						|
    return syscall(__NR_perf_event_open, attr, pid, cpu, group_fd, flags);
 | 
						|
}
 | 
						|
 | 
						|
uint64_t i915_type_id(void);
 | 
						|
 | 
						|
#endif /* I915_PERF_H */
 |