404

[ Avaa Bypassed ]




Upload:

Command:

botdev@18.188.66.142: ~ $
/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
/*
 * Performance events:
 *
 *    Copyright (C) 2008-2009, Thomas Gleixner <tglx@linutronix.de>
 *    Copyright (C) 2008-2011, Red Hat, Inc., Ingo Molnar
 *    Copyright (C) 2008-2011, Red Hat, Inc., Peter Zijlstra
 *
 * Data type definitions, declarations, prototypes.
 *
 *    Started by: Thomas Gleixner and Ingo Molnar
 *
 * For licencing details see kernel-base/COPYING
 */
#ifndef _LINUX_PERF_EVENT_H
#define _LINUX_PERF_EVENT_H

#include <linux/types.h>
#include <linux/ioctl.h>
#include <asm/byteorder.h>

/*
 * User-space ABI bits:
 */

/*
 * attr.type
 */
enum perf_type_id {
	PERF_TYPE_HARDWARE			= 0,
	PERF_TYPE_SOFTWARE			= 1,
	PERF_TYPE_TRACEPOINT			= 2,
	PERF_TYPE_HW_CACHE			= 3,
	PERF_TYPE_RAW				= 4,
	PERF_TYPE_BREAKPOINT			= 5,

	PERF_TYPE_MAX,				/* non-ABI */
};

/*
 * Generalized performance event event_id types, used by the
 * attr.event_id parameter of the sys_perf_event_open()
 * syscall:
 */
enum perf_hw_id {
	/*
	 * Common hardware events, generalized by the kernel:
	 */
	PERF_COUNT_HW_CPU_CYCLES		= 0,
	PERF_COUNT_HW_INSTRUCTIONS		= 1,
	PERF_COUNT_HW_CACHE_REFERENCES		= 2,
	PERF_COUNT_HW_CACHE_MISSES		= 3,
	PERF_COUNT_HW_BRANCH_INSTRUCTIONS	= 4,
	PERF_COUNT_HW_BRANCH_MISSES		= 5,
	PERF_COUNT_HW_BUS_CYCLES		= 6,
	PERF_COUNT_HW_STALLED_CYCLES_FRONTEND	= 7,
	PERF_COUNT_HW_STALLED_CYCLES_BACKEND	= 8,
	PERF_COUNT_HW_REF_CPU_CYCLES		= 9,

	PERF_COUNT_HW_MAX,			/* non-ABI */
};

/*
 * Generalized hardware cache events:
 *
 *       { L1-D, L1-I, LLC, ITLB, DTLB, BPU, NODE } x
 *       { read, write, prefetch } x
 *       { accesses, misses }
 */
enum perf_hw_cache_id {
	PERF_COUNT_HW_CACHE_L1D			= 0,
	PERF_COUNT_HW_CACHE_L1I			= 1,
	PERF_COUNT_HW_CACHE_LL			= 2,
	PERF_COUNT_HW_CACHE_DTLB		= 3,
	PERF_COUNT_HW_CACHE_ITLB		= 4,
	PERF_COUNT_HW_CACHE_BPU			= 5,
	PERF_COUNT_HW_CACHE_NODE		= 6,

	PERF_COUNT_HW_CACHE_MAX,		/* non-ABI */
};

enum perf_hw_cache_op_id {
	PERF_COUNT_HW_CACHE_OP_READ		= 0,
	PERF_COUNT_HW_CACHE_OP_WRITE		= 1,
	PERF_COUNT_HW_CACHE_OP_PREFETCH		= 2,

	PERF_COUNT_HW_CACHE_OP_MAX,		/* non-ABI */
};

enum perf_hw_cache_op_result_id {
	PERF_COUNT_HW_CACHE_RESULT_ACCESS	= 0,
	PERF_COUNT_HW_CACHE_RESULT_MISS		= 1,

	PERF_COUNT_HW_CACHE_RESULT_MAX,		/* non-ABI */
};

/*
 * Special "software" events provided by the kernel, even if the hardware
 * does not support performance events. These events measure various
 * physical and sw events of the kernel (and allow the profiling of them as
 * well):
 */
enum perf_sw_ids {
	PERF_COUNT_SW_CPU_CLOCK			= 0,
	PERF_COUNT_SW_TASK_CLOCK		= 1,
	PERF_COUNT_SW_PAGE_FAULTS		= 2,
	PERF_COUNT_SW_CONTEXT_SWITCHES		= 3,
	PERF_COUNT_SW_CPU_MIGRATIONS		= 4,
	PERF_COUNT_SW_PAGE_FAULTS_MIN		= 5,
	PERF_COUNT_SW_PAGE_FAULTS_MAJ		= 6,
	PERF_COUNT_SW_ALIGNMENT_FAULTS		= 7,
	PERF_COUNT_SW_EMULATION_FAULTS		= 8,
	PERF_COUNT_SW_DUMMY			= 9,
	PERF_COUNT_SW_BPF_OUTPUT		= 10,

	PERF_COUNT_SW_MAX,			/* non-ABI */
};

/*
 * Bits that can be set in attr.sample_type to request information
 * in the overflow packets.
 */
enum perf_event_sample_format {
	PERF_SAMPLE_IP				= 1U << 0,
	PERF_SAMPLE_TID				= 1U << 1,
	PERF_SAMPLE_TIME			= 1U << 2,
	PERF_SAMPLE_ADDR			= 1U << 3,
	PERF_SAMPLE_READ			= 1U << 4,
	PERF_SAMPLE_CALLCHAIN			= 1U << 5,
	PERF_SAMPLE_ID				= 1U << 6,
	PERF_SAMPLE_CPU				= 1U << 7,
	PERF_SAMPLE_PERIOD			= 1U << 8,
	PERF_SAMPLE_STREAM_ID			= 1U << 9,
	PERF_SAMPLE_RAW				= 1U << 10,
	PERF_SAMPLE_BRANCH_STACK		= 1U << 11,
	PERF_SAMPLE_REGS_USER			= 1U << 12,
	PERF_SAMPLE_STACK_USER			= 1U << 13,
	PERF_SAMPLE_WEIGHT			= 1U << 14,
	PERF_SAMPLE_DATA_SRC			= 1U << 15,
	PERF_SAMPLE_IDENTIFIER			= 1U << 16,
	PERF_SAMPLE_TRANSACTION			= 1U << 17,
	PERF_SAMPLE_REGS_INTR			= 1U << 18,
	PERF_SAMPLE_PHYS_ADDR			= 1U << 19,

	PERF_SAMPLE_MAX = 1U << 20,		/* non-ABI */
};

/*
 * values to program into branch_sample_type when PERF_SAMPLE_BRANCH is set
 *
 * If the user does not pass priv level information via branch_sample_type,
 * the kernel uses the event's priv level. Branch and event priv levels do
 * not have to match. Branch priv level is checked for permissions.
 *
 * The branch types can be combined, however BRANCH_ANY covers all types
 * of branches and therefore it supersedes all the other types.
 */
enum perf_branch_sample_type_shift {
	PERF_SAMPLE_BRANCH_USER_SHIFT		= 0, /* user branches */
	PERF_SAMPLE_BRANCH_KERNEL_SHIFT		= 1, /* kernel branches */
	PERF_SAMPLE_BRANCH_HV_SHIFT		= 2, /* hypervisor branches */

	PERF_SAMPLE_BRANCH_ANY_SHIFT		= 3, /* any branch types */
	PERF_SAMPLE_BRANCH_ANY_CALL_SHIFT	= 4, /* any call branch */
	PERF_SAMPLE_BRANCH_ANY_RETURN_SHIFT	= 5, /* any return branch */
	PERF_SAMPLE_BRANCH_IND_CALL_SHIFT	= 6, /* indirect calls */
	PERF_SAMPLE_BRANCH_ABORT_TX_SHIFT	= 7, /* transaction aborts */
	PERF_SAMPLE_BRANCH_IN_TX_SHIFT		= 8, /* in transaction */
	PERF_SAMPLE_BRANCH_NO_TX_SHIFT		= 9, /* not in transaction */
	PERF_SAMPLE_BRANCH_COND_SHIFT		= 10, /* conditional branches */

	PERF_SAMPLE_BRANCH_CALL_STACK_SHIFT	= 11, /* call/ret stack */
	PERF_SAMPLE_BRANCH_IND_JUMP_SHIFT	= 12, /* indirect jumps */
	PERF_SAMPLE_BRANCH_CALL_SHIFT		= 13, /* direct call */

	PERF_SAMPLE_BRANCH_NO_FLAGS_SHIFT	= 14, /* no flags */
	PERF_SAMPLE_BRANCH_NO_CYCLES_SHIFT	= 15, /* no cycles */

	PERF_SAMPLE_BRANCH_TYPE_SAVE_SHIFT	= 16, /* save branch type */

	PERF_SAMPLE_BRANCH_MAX_SHIFT		/* non-ABI */
};

enum perf_branch_sample_type {
	PERF_SAMPLE_BRANCH_USER		= 1U << PERF_SAMPLE_BRANCH_USER_SHIFT,
	PERF_SAMPLE_BRANCH_KERNEL	= 1U << PERF_SAMPLE_BRANCH_KERNEL_SHIFT,
	PERF_SAMPLE_BRANCH_HV		= 1U << PERF_SAMPLE_BRANCH_HV_SHIFT,

	PERF_SAMPLE_BRANCH_ANY		= 1U << PERF_SAMPLE_BRANCH_ANY_SHIFT,
	PERF_SAMPLE_BRANCH_ANY_CALL	= 1U << PERF_SAMPLE_BRANCH_ANY_CALL_SHIFT,
	PERF_SAMPLE_BRANCH_ANY_RETURN	= 1U << PERF_SAMPLE_BRANCH_ANY_RETURN_SHIFT,
	PERF_SAMPLE_BRANCH_IND_CALL	= 1U << PERF_SAMPLE_BRANCH_IND_CALL_SHIFT,
	PERF_SAMPLE_BRANCH_ABORT_TX	= 1U << PERF_SAMPLE_BRANCH_ABORT_TX_SHIFT,
	PERF_SAMPLE_BRANCH_IN_TX	= 1U << PERF_SAMPLE_BRANCH_IN_TX_SHIFT,
	PERF_SAMPLE_BRANCH_NO_TX	= 1U << PERF_SAMPLE_BRANCH_NO_TX_SHIFT,
	PERF_SAMPLE_BRANCH_COND		= 1U << PERF_SAMPLE_BRANCH_COND_SHIFT,

	PERF_SAMPLE_BRANCH_CALL_STACK	= 1U << PERF_SAMPLE_BRANCH_CALL_STACK_SHIFT,
	PERF_SAMPLE_BRANCH_IND_JUMP	= 1U << PERF_SAMPLE_BRANCH_IND_JUMP_SHIFT,
	PERF_SAMPLE_BRANCH_CALL		= 1U << PERF_SAMPLE_BRANCH_CALL_SHIFT,

	PERF_SAMPLE_BRANCH_NO_FLAGS	= 1U << PERF_SAMPLE_BRANCH_NO_FLAGS_SHIFT,
	PERF_SAMPLE_BRANCH_NO_CYCLES	= 1U << PERF_SAMPLE_BRANCH_NO_CYCLES_SHIFT,

	PERF_SAMPLE_BRANCH_TYPE_SAVE	=
		1U << PERF_SAMPLE_BRANCH_TYPE_SAVE_SHIFT,

	PERF_SAMPLE_BRANCH_MAX		= 1U << PERF_SAMPLE_BRANCH_MAX_SHIFT,
};

/*
 * Common flow change classification
 */
enum {
	PERF_BR_UNKNOWN		= 0,	/* unknown */
	PERF_BR_COND		= 1,	/* conditional */
	PERF_BR_UNCOND		= 2,	/* unconditional  */
	PERF_BR_IND		= 3,	/* indirect */
	PERF_BR_CALL		= 4,	/* function call */
	PERF_BR_IND_CALL	= 5,	/* indirect function call */
	PERF_BR_RET		= 6,	/* function return */
	PERF_BR_SYSCALL		= 7,	/* syscall */
	PERF_BR_SYSRET		= 8,	/* syscall return */
	PERF_BR_COND_CALL	= 9,	/* conditional function call */
	PERF_BR_COND_RET	= 10,	/* conditional function return */
	PERF_BR_MAX,
};

#define PERF_SAMPLE_BRANCH_PLM_ALL \
	(PERF_SAMPLE_BRANCH_USER|\
	 PERF_SAMPLE_BRANCH_KERNEL|\
	 PERF_SAMPLE_BRANCH_HV)

/*
 * Values to determine ABI of the registers dump.
 */
enum perf_sample_regs_abi {
	PERF_SAMPLE_REGS_ABI_NONE	= 0,
	PERF_SAMPLE_REGS_ABI_32		= 1,
	PERF_SAMPLE_REGS_ABI_64		= 2,
};

/*
 * Values for the memory transaction event qualifier, mostly for
 * abort events. Multiple bits can be set.
 */
enum {
	PERF_TXN_ELISION        = (1 << 0), /* From elision */
	PERF_TXN_TRANSACTION    = (1 << 1), /* From transaction */
	PERF_TXN_SYNC           = (1 << 2), /* Instruction is related */
	PERF_TXN_ASYNC          = (1 << 3), /* Instruction not related */
	PERF_TXN_RETRY          = (1 << 4), /* Retry possible */
	PERF_TXN_CONFLICT       = (1 << 5), /* Conflict abort */
	PERF_TXN_CAPACITY_WRITE = (1 << 6), /* Capacity write abort */
	PERF_TXN_CAPACITY_READ  = (1 << 7), /* Capacity read abort */

	PERF_TXN_MAX	        = (1 << 8), /* non-ABI */

	/* bits 32..63 are reserved for the abort code */

	PERF_TXN_ABORT_MASK  = (0xffffffffULL << 32),
	PERF_TXN_ABORT_SHIFT = 32,
};

/*
 * The format of the data returned by read() on a perf event fd,
 * as specified by attr.read_format:
 *
 * struct read_format {
 *	{ u64		value;
 *	  { u64		time_enabled; } && PERF_FORMAT_TOTAL_TIME_ENABLED
 *	  { u64		time_running; } && PERF_FORMAT_TOTAL_TIME_RUNNING
 *	  { u64		id;           } && PERF_FORMAT_ID
 *	} && !PERF_FORMAT_GROUP
 *
 *	{ u64		nr;
 *	  { u64		time_enabled; } && PERF_FORMAT_TOTAL_TIME_ENABLED
 *	  { u64		time_running; } && PERF_FORMAT_TOTAL_TIME_RUNNING
 *	  { u64		value;
 *	    { u64	id;           } && PERF_FORMAT_ID
 *	  }		cntr[nr];
 *	} && PERF_FORMAT_GROUP
 * };
 */
enum perf_event_read_format {
	PERF_FORMAT_TOTAL_TIME_ENABLED		= 1U << 0,
	PERF_FORMAT_TOTAL_TIME_RUNNING		= 1U << 1,
	PERF_FORMAT_ID				= 1U << 2,
	PERF_FORMAT_GROUP			= 1U << 3,

	PERF_FORMAT_MAX = 1U << 4,		/* non-ABI */
};

#define PERF_ATTR_SIZE_VER0	64	/* sizeof first published struct */
#define PERF_ATTR_SIZE_VER1	72	/* add: config2 */
#define PERF_ATTR_SIZE_VER2	80	/* add: branch_sample_type */
#define PERF_ATTR_SIZE_VER3	96	/* add: sample_regs_user */
					/* add: sample_stack_user */
#define PERF_ATTR_SIZE_VER4	104	/* add: sample_regs_intr */
#define PERF_ATTR_SIZE_VER5	112	/* add: aux_watermark */

/*
 * Hardware event_id to monitor via a performance monitoring event:
 *
 * @sample_max_stack: Max number of frame pointers in a callchain,
 *		      should be < /proc/sys/kernel/perf_event_max_stack
 */
struct perf_event_attr {

	/*
	 * Major type: hardware/software/tracepoint/etc.
	 */
	__u32			type;

	/*
	 * Size of the attr structure, for fwd/bwd compat.
	 */
	__u32			size;

	/*
	 * Type specific configuration information.
	 */
	__u64			config;

	union {
		__u64		sample_period;
		__u64		sample_freq;
	};

	__u64			sample_type;
	__u64			read_format;

	__u64			disabled       :  1, /* off by default        */
				inherit	       :  1, /* children inherit it   */
				pinned	       :  1, /* must always be on PMU */
				exclusive      :  1, /* only group on PMU     */
				exclude_user   :  1, /* don't count user      */
				exclude_kernel :  1, /* ditto kernel          */
				exclude_hv     :  1, /* ditto hypervisor      */
				exclude_idle   :  1, /* don't count when idle */
				mmap           :  1, /* include mmap data     */
				comm	       :  1, /* include comm data     */
				freq           :  1, /* use freq, not period  */
				inherit_stat   :  1, /* per task counts       */
				enable_on_exec :  1, /* next exec enables     */
				task           :  1, /* trace fork/exit       */
				watermark      :  1, /* wakeup_watermark      */
				/*
				 * precise_ip:
				 *
				 *  0 - SAMPLE_IP can have arbitrary skid
				 *  1 - SAMPLE_IP must have constant skid
				 *  2 - SAMPLE_IP requested to have 0 skid
				 *  3 - SAMPLE_IP must have 0 skid
				 *
				 *  See also PERF_RECORD_MISC_EXACT_IP
				 */
				precise_ip     :  2, /* skid constraint       */
				mmap_data      :  1, /* non-exec mmap data    */
				sample_id_all  :  1, /* sample_type all events */

				exclude_host   :  1, /* don't count in host   */
				exclude_guest  :  1, /* don't count in guest  */

				exclude_callchain_kernel : 1, /* exclude kernel callchains */
				exclude_callchain_user   : 1, /* exclude user callchains */
				mmap2          :  1, /* include mmap with inode data     */
				comm_exec      :  1, /* flag comm events that are due to an exec */
				use_clockid    :  1, /* use @clockid for time fields */
				context_switch :  1, /* context switch data */
				write_backward :  1, /* Write ring buffer from end to beginning */
				namespaces     :  1, /* include namespaces data */
				__reserved_1   : 35;

	union {
		__u32		wakeup_events;	  /* wakeup every n events */
		__u32		wakeup_watermark; /* bytes before wakeup   */
	};

	__u32			bp_type;
	union {
		__u64		bp_addr;
		__u64		config1; /* extension of config */
	};
	union {
		__u64		bp_len;
		__u64		config2; /* extension of config1 */
	};
	__u64	branch_sample_type; /* enum perf_branch_sample_type */

	/*
	 * Defines set of user regs to dump on samples.
	 * See asm/perf_regs.h for details.
	 */
	__u64	sample_regs_user;

	/*
	 * Defines size of the user stack to dump on samples.
	 */
	__u32	sample_stack_user;

	__s32	clockid;
	/*
	 * Defines set of regs to dump for each sample
	 * state captured on:
	 *  - precise = 0: PMU interrupt
	 *  - precise > 0: sampled instruction
	 *
	 * See asm/perf_regs.h for details.
	 */
	__u64	sample_regs_intr;

	/*
	 * Wakeup watermark for AUX area
	 */
	__u32	aux_watermark;
	__u16	sample_max_stack;
	__u16	__reserved_2;	/* align to __u64 */
};

#define perf_flags(attr)	(*(&(attr)->read_format + 1))

/*
 * Ioctls that can be done on a perf event fd:
 */
#define PERF_EVENT_IOC_ENABLE		_IO ('$', 0)
#define PERF_EVENT_IOC_DISABLE		_IO ('$', 1)
#define PERF_EVENT_IOC_REFRESH		_IO ('$', 2)
#define PERF_EVENT_IOC_RESET		_IO ('$', 3)
#define PERF_EVENT_IOC_PERIOD		_IOW('$', 4, __u64)
#define PERF_EVENT_IOC_SET_OUTPUT	_IO ('$', 5)
#define PERF_EVENT_IOC_SET_FILTER	_IOW('$', 6, char *)
#define PERF_EVENT_IOC_ID		_IOR('$', 7, __u64 *)
#define PERF_EVENT_IOC_SET_BPF		_IOW('$', 8, __u32)
#define PERF_EVENT_IOC_PAUSE_OUTPUT	_IOW('$', 9, __u32)

enum perf_event_ioc_flags {
	PERF_IOC_FLAG_GROUP		= 1U << 0,
};

/*
 * Structure of the page that can be mapped via mmap
 */
struct perf_event_mmap_page {
	__u32	version;		/* version number of this structure */
	__u32	compat_version;		/* lowest version this is compat with */

	/*
	 * Bits needed to read the hw events in user-space.
	 *
	 *   u32 seq, time_mult, time_shift, index, width;
	 *   u64 count, enabled, running;
	 *   u64 cyc, time_offset;
	 *   s64 pmc = 0;
	 *
	 *   do {
	 *     seq = pc->lock;
	 *     barrier()
	 *
	 *     enabled = pc->time_enabled;
	 *     running = pc->time_running;
	 *
	 *     if (pc->cap_usr_time && enabled != running) {
	 *       cyc = rdtsc();
	 *       time_offset = pc->time_offset;
	 *       time_mult   = pc->time_mult;
	 *       time_shift  = pc->time_shift;
	 *     }
	 *
	 *     index = pc->index;
	 *     count = pc->offset;
	 *     if (pc->cap_user_rdpmc && index) {
	 *       width = pc->pmc_width;
	 *       pmc = rdpmc(index - 1);
	 *     }
	 *
	 *     barrier();
	 *   } while (pc->lock != seq);
	 *
	 * NOTE: for obvious reason this only works on self-monitoring
	 *       processes.
	 */
	__u32	lock;			/* seqlock for synchronization */
	__u32	index;			/* hardware event identifier */
	__s64	offset;			/* add to hardware event value */
	__u64	time_enabled;		/* time event active */
	__u64	time_running;		/* time event on cpu */
	union {
		__u64	capabilities;
		struct {
			__u64	cap_bit0		: 1, /* Always 0, deprecated, see commit 860f085b74e9 */
				cap_bit0_is_deprecated	: 1, /* Always 1, signals that bit 0 is zero */

				cap_user_rdpmc		: 1, /* The RDPMC instruction can be used to read counts */
				cap_user_time		: 1, /* The time_* fields are used */
				cap_user_time_zero	: 1, /* The time_zero field is used */
				cap_____res		: 59;
		};
	};

	/*
	 * If cap_user_rdpmc this field provides the bit-width of the value
	 * read using the rdpmc() or equivalent instruction. This can be used
	 * to sign extend the result like:
	 *
	 *   pmc <<= 64 - width;
	 *   pmc >>= 64 - width; // signed shift right
	 *   count += pmc;
	 */
	__u16	pmc_width;

	/*
	 * If cap_usr_time the below fields can be used to compute the time
	 * delta since time_enabled (in ns) using rdtsc or similar.
	 *
	 *   u64 quot, rem;
	 *   u64 delta;
	 *
	 *   quot = (cyc >> time_shift);
	 *   rem = cyc & (((u64)1 << time_shift) - 1);
	 *   delta = time_offset + quot * time_mult +
	 *              ((rem * time_mult) >> time_shift);
	 *
	 * Where time_offset,time_mult,time_shift and cyc are read in the
	 * seqcount loop described above. This delta can then be added to
	 * enabled and possible running (if index), improving the scaling:
	 *
	 *   enabled += delta;
	 *   if (index)
	 *     running += delta;
	 *
	 *   quot = count / running;
	 *   rem  = count % running;
	 *   count = quot * enabled + (rem * enabled) / running;
	 */
	__u16	time_shift;
	__u32	time_mult;
	__u64	time_offset;
	/*
	 * If cap_usr_time_zero, the hardware clock (e.g. TSC) can be calculated
	 * from sample timestamps.
	 *
	 *   time = timestamp - time_zero;
	 *   quot = time / time_mult;
	 *   rem  = time % time_mult;
	 *   cyc = (quot << time_shift) + (rem << time_shift) / time_mult;
	 *
	 * And vice versa:
	 *
	 *   quot = cyc >> time_shift;
	 *   rem  = cyc & (((u64)1 << time_shift) - 1);
	 *   timestamp = time_zero + quot * time_mult +
	 *               ((rem * time_mult) >> time_shift);
	 */
	__u64	time_zero;
	__u32	size;			/* Header size up to __reserved[] fields. */

		/*
		 * Hole for extension of the self monitor capabilities
		 */

	__u8	__reserved[118*8+4];	/* align to 1k. */

	/*
	 * Control data for the mmap() data buffer.
	 *
	 * User-space reading the @data_head value should issue an smp_rmb(),
	 * after reading this value.
	 *
	 * When the mapping is PROT_WRITE the @data_tail value should be
	 * written by userspace to reflect the last read data, after issueing
	 * an smp_mb() to separate the data read from the ->data_tail store.
	 * In this case the kernel will not over-write unread data.
	 *
	 * See perf_output_put_handle() for the data ordering.
	 *
	 * data_{offset,size} indicate the location and size of the perf record
	 * buffer within the mmapped area.
	 */
	__u64   data_head;		/* head in the data section */
	__u64	data_tail;		/* user-space written tail */
	__u64	data_offset;		/* where the buffer starts */
	__u64	data_size;		/* data buffer size */

	/*
	 * AUX area is defined by aux_{offset,size} fields that should be set
	 * by the userspace, so that
	 *
	 *   aux_offset >= data_offset + data_size
	 *
	 * prior to mmap()ing it. Size of the mmap()ed area should be aux_size.
	 *
	 * Ring buffer pointers aux_{head,tail} have the same semantics as
	 * data_{head,tail} and same ordering rules apply.
	 */
	__u64	aux_head;
	__u64	aux_tail;
	__u64	aux_offset;
	__u64	aux_size;
};

#define PERF_RECORD_MISC_CPUMODE_MASK		(7 << 0)
#define PERF_RECORD_MISC_CPUMODE_UNKNOWN	(0 << 0)
#define PERF_RECORD_MISC_KERNEL			(1 << 0)
#define PERF_RECORD_MISC_USER			(2 << 0)
#define PERF_RECORD_MISC_HYPERVISOR		(3 << 0)
#define PERF_RECORD_MISC_GUEST_KERNEL		(4 << 0)
#define PERF_RECORD_MISC_GUEST_USER		(5 << 0)

/*
 * Indicates that /proc/PID/maps parsing are truncated by time out.
 */
#define PERF_RECORD_MISC_PROC_MAP_PARSE_TIMEOUT	(1 << 12)
/*
 * PERF_RECORD_MISC_MMAP_DATA and PERF_RECORD_MISC_COMM_EXEC are used on
 * different events so can reuse the same bit position.
 * Ditto PERF_RECORD_MISC_SWITCH_OUT.
 */
#define PERF_RECORD_MISC_MMAP_DATA		(1 << 13)
#define PERF_RECORD_MISC_COMM_EXEC		(1 << 13)
#define PERF_RECORD_MISC_SWITCH_OUT		(1 << 13)
/*
 * Indicates that the content of PERF_SAMPLE_IP points to
 * the actual instruction that triggered the event. See also
 * perf_event_attr::precise_ip.
 */
#define PERF_RECORD_MISC_EXACT_IP		(1 << 14)
/*
 * Reserve the last bit to indicate some extended misc field
 */
#define PERF_RECORD_MISC_EXT_RESERVED		(1 << 15)

struct perf_event_header {
	__u32	type;
	__u16	misc;
	__u16	size;
};

struct perf_ns_link_info {
	__u64	dev;
	__u64	ino;
};

enum {
	NET_NS_INDEX		= 0,
	UTS_NS_INDEX		= 1,
	IPC_NS_INDEX		= 2,
	PID_NS_INDEX		= 3,
	USER_NS_INDEX		= 4,
	MNT_NS_INDEX		= 5,
	CGROUP_NS_INDEX		= 6,

	NR_NAMESPACES,		/* number of available namespaces */
};

enum perf_event_type {

	/*
	 * If perf_event_attr.sample_id_all is set then all event types will
	 * have the sample_type selected fields related to where/when
	 * (identity) an event took place (TID, TIME, ID, STREAM_ID, CPU,
	 * IDENTIFIER) described in PERF_RECORD_SAMPLE below, it will be stashed
	 * just after the perf_event_header and the fields already present for
	 * the existing fields, i.e. at the end of the payload. That way a newer
	 * perf.data file will be supported by older perf tools, with these new
	 * optional fields being ignored.
	 *
	 * struct sample_id {
	 * 	{ u32			pid, tid; } && PERF_SAMPLE_TID
	 * 	{ u64			time;     } && PERF_SAMPLE_TIME
	 * 	{ u64			id;       } && PERF_SAMPLE_ID
	 * 	{ u64			stream_id;} && PERF_SAMPLE_STREAM_ID
	 * 	{ u32			cpu, res; } && PERF_SAMPLE_CPU
	 *	{ u64			id;	  } && PERF_SAMPLE_IDENTIFIER
	 * } && perf_event_attr::sample_id_all
	 *
	 * Note that PERF_SAMPLE_IDENTIFIER duplicates PERF_SAMPLE_ID.  The
	 * advantage of PERF_SAMPLE_IDENTIFIER is that its position is fixed
	 * relative to header.size.
	 */

	/*
	 * The MMAP events record the PROT_EXEC mappings so that we can
	 * correlate userspace IPs to code. They have the following structure:
	 *
	 * struct {
	 *	struct perf_event_header	header;
	 *
	 *	u32				pid, tid;
	 *	u64				addr;
	 *	u64				len;
	 *	u64				pgoff;
	 *	char				filename[];
	 * 	struct sample_id		sample_id;
	 * };
	 */
	PERF_RECORD_MMAP			= 1,

	/*
	 * struct {
	 *	struct perf_event_header	header;
	 *	u64				id;
	 *	u64				lost;
	 * 	struct sample_id		sample_id;
	 * };
	 */
	PERF_RECORD_LOST			= 2,

	/*
	 * struct {
	 *	struct perf_event_header	header;
	 *
	 *	u32				pid, tid;
	 *	char				comm[];
	 * 	struct sample_id		sample_id;
	 * };
	 */
	PERF_RECORD_COMM			= 3,

	/*
	 * struct {
	 *	struct perf_event_header	header;
	 *	u32				pid, ppid;
	 *	u32				tid, ptid;
	 *	u64				time;
	 * 	struct sample_id		sample_id;
	 * };
	 */
	PERF_RECORD_EXIT			= 4,

	/*
	 * struct {
	 *	struct perf_event_header	header;
	 *	u64				time;
	 *	u64				id;
	 *	u64				stream_id;
	 * 	struct sample_id		sample_id;
	 * };
	 */
	PERF_RECORD_THROTTLE			= 5,
	PERF_RECORD_UNTHROTTLE			= 6,

	/*
	 * struct {
	 *	struct perf_event_header	header;
	 *	u32				pid, ppid;
	 *	u32				tid, ptid;
	 *	u64				time;
	 * 	struct sample_id		sample_id;
	 * };
	 */
	PERF_RECORD_FORK			= 7,

	/*
	 * struct {
	 *	struct perf_event_header	header;
	 *	u32				pid, tid;
	 *
	 *	struct read_format		values;
	 * 	struct sample_id		sample_id;
	 * };
	 */
	PERF_RECORD_READ			= 8,

	/*
	 * struct {
	 *	struct perf_event_header	header;
	 *
	 *	#
	 *	# Note that PERF_SAMPLE_IDENTIFIER duplicates PERF_SAMPLE_ID.
	 *	# The advantage of PERF_SAMPLE_IDENTIFIER is that its position
	 *	# is fixed relative to header.
	 *	#
	 *
	 *	{ u64			id;	  } && PERF_SAMPLE_IDENTIFIER
	 *	{ u64			ip;	  } && PERF_SAMPLE_IP
	 *	{ u32			pid, tid; } && PERF_SAMPLE_TID
	 *	{ u64			time;     } && PERF_SAMPLE_TIME
	 *	{ u64			addr;     } && PERF_SAMPLE_ADDR
	 *	{ u64			id;	  } && PERF_SAMPLE_ID
	 *	{ u64			stream_id;} && PERF_SAMPLE_STREAM_ID
	 *	{ u32			cpu, res; } && PERF_SAMPLE_CPU
	 *	{ u64			period;   } && PERF_SAMPLE_PERIOD
	 *
	 *	{ struct read_format	values;	  } && PERF_SAMPLE_READ
	 *
	 *	{ u64			nr,
	 *	  u64			ips[nr];  } && PERF_SAMPLE_CALLCHAIN
	 *
	 *	#
	 *	# The RAW record below is opaque data wrt the ABI
	 *	#
	 *	# That is, the ABI doesn't make any promises wrt to
	 *	# the stability of its content, it may vary depending
	 *	# on event, hardware, kernel version and phase of
	 *	# the moon.
	 *	#
	 *	# In other words, PERF_SAMPLE_RAW contents are not an ABI.
	 *	#
	 *
	 *	{ u32			size;
	 *	  char                  data[size];}&& PERF_SAMPLE_RAW
	 *
	 *	{ u64                   nr;
	 *        { u64 from, to, flags } lbr[nr];} && PERF_SAMPLE_BRANCH_STACK
	 *
	 * 	{ u64			abi; # enum perf_sample_regs_abi
	 * 	  u64			regs[weight(mask)]; } && PERF_SAMPLE_REGS_USER
	 *
	 * 	{ u64			size;
	 * 	  char			data[size];
	 * 	  u64			dyn_size; } && PERF_SAMPLE_STACK_USER
	 *
	 *	{ u64			weight;   } && PERF_SAMPLE_WEIGHT
	 *	{ u64			data_src; } && PERF_SAMPLE_DATA_SRC
	 *	{ u64			transaction; } && PERF_SAMPLE_TRANSACTION
	 *	{ u64			abi; # enum perf_sample_regs_abi
	 *	  u64			regs[weight(mask)]; } && PERF_SAMPLE_REGS_INTR
	 *	{ u64			phys_addr;} && PERF_SAMPLE_PHYS_ADDR
	 * };
	 */
	PERF_RECORD_SAMPLE			= 9,

	/*
	 * The MMAP2 records are an augmented version of MMAP, they add
	 * maj, min, ino numbers to be used to uniquely identify each mapping
	 *
	 * struct {
	 *	struct perf_event_header	header;
	 *
	 *	u32				pid, tid;
	 *	u64				addr;
	 *	u64				len;
	 *	u64				pgoff;
	 *	u32				maj;
	 *	u32				min;
	 *	u64				ino;
	 *	u64				ino_generation;
	 *	u32				prot, flags;
	 *	char				filename[];
	 * 	struct sample_id		sample_id;
	 * };
	 */
	PERF_RECORD_MMAP2			= 10,

	/*
	 * Records that new data landed in the AUX buffer part.
	 *
	 * struct {
	 * 	struct perf_event_header	header;
	 *
	 * 	u64				aux_offset;
	 * 	u64				aux_size;
	 *	u64				flags;
	 * 	struct sample_id		sample_id;
	 * };
	 */
	PERF_RECORD_AUX				= 11,

	/*
	 * Indicates that instruction trace has started
	 *
	 * struct {
	 *	struct perf_event_header	header;
	 *	u32				pid;
	 *	u32				tid;
	 * };
	 */
	PERF_RECORD_ITRACE_START		= 12,

	/*
	 * Records the dropped/lost sample number.
	 *
	 * struct {
	 *	struct perf_event_header	header;
	 *
	 *	u64				lost;
	 *	struct sample_id		sample_id;
	 * };
	 */
	PERF_RECORD_LOST_SAMPLES		= 13,

	/*
	 * Records a context switch in or out (flagged by
	 * PERF_RECORD_MISC_SWITCH_OUT). See also
	 * PERF_RECORD_SWITCH_CPU_WIDE.
	 *
	 * struct {
	 *	struct perf_event_header	header;
	 *	struct sample_id		sample_id;
	 * };
	 */
	PERF_RECORD_SWITCH			= 14,

	/*
	 * CPU-wide version of PERF_RECORD_SWITCH with next_prev_pid and
	 * next_prev_tid that are the next (switching out) or previous
	 * (switching in) pid/tid.
	 *
	 * struct {
	 *	struct perf_event_header	header;
	 *	u32				next_prev_pid;
	 *	u32				next_prev_tid;
	 *	struct sample_id		sample_id;
	 * };
	 */
	PERF_RECORD_SWITCH_CPU_WIDE		= 15,

	/*
	 * struct {
	 *	struct perf_event_header	header;
	 *	u32				pid;
	 *	u32				tid;
	 *	u64				nr_namespaces;
	 *	{ u64				dev, inode; } [nr_namespaces];
	 *	struct sample_id		sample_id;
	 * };
	 */
	PERF_RECORD_NAMESPACES			= 16,

	PERF_RECORD_MAX,			/* non-ABI */
};

#define PERF_MAX_STACK_DEPTH		127
#define PERF_MAX_CONTEXTS_PER_STACK	  8

enum perf_callchain_context {
	PERF_CONTEXT_HV			= (__u64)-32,
	PERF_CONTEXT_KERNEL		= (__u64)-128,
	PERF_CONTEXT_USER		= (__u64)-512,

	PERF_CONTEXT_GUEST		= (__u64)-2048,
	PERF_CONTEXT_GUEST_KERNEL	= (__u64)-2176,
	PERF_CONTEXT_GUEST_USER		= (__u64)-2560,

	PERF_CONTEXT_MAX		= (__u64)-4095,
};

/**
 * PERF_RECORD_AUX::flags bits
 */
#define PERF_AUX_FLAG_TRUNCATED		0x01	/* record was truncated to fit */
#define PERF_AUX_FLAG_OVERWRITE		0x02	/* snapshot from overwrite mode */
#define PERF_AUX_FLAG_PARTIAL		0x04	/* record contains gaps */
#define PERF_AUX_FLAG_COLLISION		0x08	/* sample collided with another */

#define PERF_FLAG_FD_NO_GROUP		(1UL << 0)
#define PERF_FLAG_FD_OUTPUT		(1UL << 1)
#define PERF_FLAG_PID_CGROUP		(1UL << 2) /* pid=cgroup id, per-cpu mode only */
#define PERF_FLAG_FD_CLOEXEC		(1UL << 3) /* O_CLOEXEC */

#if defined(__LITTLE_ENDIAN_BITFIELD)
union perf_mem_data_src {
	__u64 val;
	struct {
		__u64   mem_op:5,	/* type of opcode */
			mem_lvl:14,	/* memory hierarchy level */
			mem_snoop:5,	/* snoop mode */
			mem_lock:2,	/* lock instr */
			mem_dtlb:7,	/* tlb access */
			mem_lvl_num:4,	/* memory hierarchy level number */
			mem_remote:1,   /* remote */
			mem_snoopx:2,	/* snoop mode, ext */
			mem_rsvd:24;
	};
};
#elif defined(__BIG_ENDIAN_BITFIELD)
union perf_mem_data_src {
	__u64 val;
	struct {
		__u64	mem_rsvd:24,
			mem_snoopx:2,	/* snoop mode, ext */
			mem_remote:1,   /* remote */
			mem_lvl_num:4,	/* memory hierarchy level number */
			mem_dtlb:7,	/* tlb access */
			mem_lock:2,	/* lock instr */
			mem_snoop:5,	/* snoop mode */
			mem_lvl:14,	/* memory hierarchy level */
			mem_op:5;	/* type of opcode */
	};
};
#else
#error "Unknown endianness"
#endif

/* type of opcode (load/store/prefetch,code) */
#define PERF_MEM_OP_NA		0x01 /* not available */
#define PERF_MEM_OP_LOAD	0x02 /* load instruction */
#define PERF_MEM_OP_STORE	0x04 /* store instruction */
#define PERF_MEM_OP_PFETCH	0x08 /* prefetch */
#define PERF_MEM_OP_EXEC	0x10 /* code (execution) */
#define PERF_MEM_OP_SHIFT	0

/* memory hierarchy (memory level, hit or miss) */
#define PERF_MEM_LVL_NA		0x01  /* not available */
#define PERF_MEM_LVL_HIT	0x02  /* hit level */
#define PERF_MEM_LVL_MISS	0x04  /* miss level  */
#define PERF_MEM_LVL_L1		0x08  /* L1 */
#define PERF_MEM_LVL_LFB	0x10  /* Line Fill Buffer */
#define PERF_MEM_LVL_L2		0x20  /* L2 */
#define PERF_MEM_LVL_L3		0x40  /* L3 */
#define PERF_MEM_LVL_LOC_RAM	0x80  /* Local DRAM */
#define PERF_MEM_LVL_REM_RAM1	0x100 /* Remote DRAM (1 hop) */
#define PERF_MEM_LVL_REM_RAM2	0x200 /* Remote DRAM (2 hops) */
#define PERF_MEM_LVL_REM_CCE1	0x400 /* Remote Cache (1 hop) */
#define PERF_MEM_LVL_REM_CCE2	0x800 /* Remote Cache (2 hops) */
#define PERF_MEM_LVL_IO		0x1000 /* I/O memory */
#define PERF_MEM_LVL_UNC	0x2000 /* Uncached memory */
#define PERF_MEM_LVL_SHIFT	5

#define PERF_MEM_REMOTE_REMOTE	0x01  /* Remote */
#define PERF_MEM_REMOTE_SHIFT	37

#define PERF_MEM_LVLNUM_L1	0x01 /* L1 */
#define PERF_MEM_LVLNUM_L2	0x02 /* L2 */
#define PERF_MEM_LVLNUM_L3	0x03 /* L3 */
#define PERF_MEM_LVLNUM_L4	0x04 /* L4 */
/* 5-0xa available */
#define PERF_MEM_LVLNUM_ANY_CACHE 0x0b /* Any cache */
#define PERF_MEM_LVLNUM_LFB	0x0c /* LFB */
#define PERF_MEM_LVLNUM_RAM	0x0d /* RAM */
#define PERF_MEM_LVLNUM_PMEM	0x0e /* PMEM */
#define PERF_MEM_LVLNUM_NA	0x0f /* N/A */

#define PERF_MEM_LVLNUM_SHIFT	33

/* snoop mode */
#define PERF_MEM_SNOOP_NA	0x01 /* not available */
#define PERF_MEM_SNOOP_NONE	0x02 /* no snoop */
#define PERF_MEM_SNOOP_HIT	0x04 /* snoop hit */
#define PERF_MEM_SNOOP_MISS	0x08 /* snoop miss */
#define PERF_MEM_SNOOP_HITM	0x10 /* snoop hit modified */
#define PERF_MEM_SNOOP_SHIFT	19

#define PERF_MEM_SNOOPX_FWD	0x01 /* forward */
/* 1 free */
#define PERF_MEM_SNOOPX_SHIFT  38

/* locked instruction */
#define PERF_MEM_LOCK_NA	0x01 /* not available */
#define PERF_MEM_LOCK_LOCKED	0x02 /* locked transaction */
#define PERF_MEM_LOCK_SHIFT	24

/* TLB access */
#define PERF_MEM_TLB_NA		0x01 /* not available */
#define PERF_MEM_TLB_HIT	0x02 /* hit level */
#define PERF_MEM_TLB_MISS	0x04 /* miss level */
#define PERF_MEM_TLB_L1		0x08 /* L1 */
#define PERF_MEM_TLB_L2		0x10 /* L2 */
#define PERF_MEM_TLB_WK		0x20 /* Hardware Walker*/
#define PERF_MEM_TLB_OS		0x40 /* OS fault handler */
#define PERF_MEM_TLB_SHIFT	26

#define PERF_MEM_S(a, s) \
	(((__u64)PERF_MEM_##a##_##s) << PERF_MEM_##a##_SHIFT)

/*
 * single taken branch record layout:
 *
 *      from: source instruction (may not always be a branch insn)
 *        to: branch target
 *   mispred: branch target was mispredicted
 * predicted: branch target was predicted
 *
 * support for mispred, predicted is optional. In case it
 * is not supported mispred = predicted = 0.
 *
 *     in_tx: running in a hardware transaction
 *     abort: aborting a hardware transaction
 *    cycles: cycles from last branch (or 0 if not supported)
 *      type: branch type
 */
struct perf_branch_entry {
	__u64	from;
	__u64	to;
	__u64	mispred:1,  /* target mispredicted */
		predicted:1,/* target predicted */
		in_tx:1,    /* in transaction */
		abort:1,    /* transaction abort */
		cycles:16,  /* cycle count to last branch */
		type:4,     /* branch type */
		reserved:40;
};

#endif /* _LINUX_PERF_EVENT_H */

Filemanager

Name Type Size Permission Actions
android Folder 0755
byteorder Folder 0755
caif Folder 0755
can Folder 0755
cifs Folder 0755
dvb Folder 0755
genwqe Folder 0755
hdlc Folder 0755
hsi Folder 0755
iio Folder 0755
isdn Folder 0755
mmc Folder 0755
netfilter Folder 0755
netfilter_arp Folder 0755
netfilter_bridge Folder 0755
netfilter_ipv4 Folder 0755
netfilter_ipv6 Folder 0755
nfsd Folder 0755
raid Folder 0755
sched Folder 0755
spi Folder 0755
sunrpc Folder 0755
tc_act Folder 0755
tc_ematch Folder 0755
usb Folder 0755
wimax Folder 0755
a.out.h File 6.73 KB 0644
acct.h File 3.65 KB 0644
adb.h File 1.11 KB 0644
adfs_fs.h File 936 B 0644
affs_hardblocks.h File 1.51 KB 0644
agpgart.h File 3.85 KB 0644
aio_abi.h File 3.2 KB 0644
am437x-vpfe.h File 3.59 KB 0644
apm_bios.h File 3.6 KB 0644
arcfb.h File 213 B 0644
arm_sdei.h File 2.69 KB 0644
aspeed-lpc-ctrl.h File 1.74 KB 0644
atalk.h File 1023 B 0644
atm.h File 7.7 KB 0644
atm_eni.h File 648 B 0644
atm_he.h File 406 B 0644
atm_idt77105.h File 955 B 0644
atm_nicstar.h File 1.25 KB 0644
atm_tcp.h File 1.58 KB 0644
atm_zatm.h File 1.5 KB 0644
atmapi.h File 952 B 0644
atmarp.h File 1.27 KB 0644
atmbr2684.h File 3.19 KB 0644
atmclip.h File 576 B 0644
atmdev.h File 7.5 KB 0644
atmioc.h File 1.61 KB 0644
atmlec.h File 2.33 KB 0644
atmmpc.h File 4.13 KB 0644
atmppp.h File 639 B 0644
atmsap.h File 4.85 KB 0644
atmsvc.h File 1.81 KB 0644
audit.h File 19.09 KB 0644
aufs_type.h File 11.1 KB 0644
auto_dev-ioctl.h File 4.87 KB 0644
auto_fs.h File 2.6 KB 0644
auto_fs4.h File 4.17 KB 0644
auxvec.h File 1.46 KB 0644
ax25.h File 2.76 KB 0644
b1lli.h File 1.68 KB 0644
batman_adv.h File 9.23 KB 0644
baycom.h File 883 B 0644
bcache.h File 8.17 KB 0644
bcm933xx_hcs.h File 419 B 0644
bfs_fs.h File 1.85 KB 0644
binfmts.h File 628 B 0644
blkpg.h File 1.6 KB 0644
blktrace_api.h File 4.59 KB 0644
blkzoned.h File 5.05 KB 0644
bpf.h File 30.32 KB 0644
bpf_common.h File 1.26 KB 0644
bpf_perf_event.h File 516 B 0644
bpqether.h File 981 B 0644
bsg.h File 2.44 KB 0644
bt-bmc.h File 572 B 0644
btrfs.h File 25.75 KB 0644
btrfs_tree.h File 24.64 KB 0644
can.h File 7.7 KB 0644
capability.h File 11.5 KB 0644
capi.h File 3.05 KB 0644
cciss_defs.h File 3.2 KB 0644
cciss_ioctl.h File 2.7 KB 0644
cdrom.h File 28.18 KB 0644
cec-funcs.h File 53.82 KB 0644
cec.h File 36.77 KB 0644
cgroupstats.h File 2.17 KB 0644
chio.h File 5.22 KB 0644
cm4000_cs.h File 1.76 KB 0644
cn_proc.h File 3.26 KB 0644
coda.h File 17.09 KB 0644
coda_psdev.h File 360 B 0644
coff.h File 12.18 KB 0644
connector.h File 2.2 KB 0644
const.h File 993 B 0644
coresight-stm.h File 706 B 0644
cramfs_fs.h File 3.47 KB 0644
cryptouser.h File 3.31 KB 0644
cuda.h File 905 B 0644
cyclades.h File 16.71 KB 0644
cycx_cfm.h File 2.92 KB 0644
dcbnl.h File 24.37 KB 0644
dccp.h File 6.29 KB 0644
devlink.h File 7.15 KB 0644
dlm.h File 2.49 KB 0644
dlm_device.h File 2.48 KB 0644
dlm_netlink.h File 1.13 KB 0644
dlm_plock.h File 894 B 0644
dlmconstants.h File 4.96 KB 0644
dm-ioctl.h File 10.62 KB 0644
dm-log-userspace.h File 14.83 KB 0644
dma-buf.h File 1.33 KB 0644
dn.h File 4.53 KB 0644
dqblk_xfs.h File 8.79 KB 0644
edd.h File 5.47 KB 0644
efs_fs_sb.h File 2.17 KB 0644
elf-em.h File 2.14 KB 0644
elf-fdpic.h File 1.1 KB 0644
elf.h File 12.99 KB 0644
elfcore.h File 2.92 KB 0644
errno.h File 23 B 0644
errqueue.h File 1.34 KB 0644
ethtool.h File 69.81 KB 0644
eventpoll.h File 2.48 KB 0644
fadvise.h File 842 B 0644
falloc.h File 3.5 KB 0644
fanotify.h File 3.59 KB 0644
fb.h File 16.06 KB 0644
fcntl.h File 3.22 KB 0644
fd.h File 11.4 KB 0644
fdreg.h File 5.29 KB 0644
fib_rules.h File 1.79 KB 0644
fiemap.h File 2.71 KB 0644
filter.h File 2.16 KB 0644
firewire-cdev.h File 42.86 KB 0644
firewire-constants.h File 3.16 KB 0644
flat.h File 2.1 KB 0644
fou.h File 694 B 0644
fs.h File 14.47 KB 0644
fsl_hypervisor.h File 7.13 KB 0644
fsmap.h File 4.29 KB 0644
fuse.h File 17.06 KB 0644
futex.h File 4.88 KB 0644
gameport.h File 897 B 0644
gen_stats.h File 1.54 KB 0644
genetlink.h File 1.88 KB 0644
gfs2_ondisk.h File 12.07 KB 0644
gigaset_dev.h File 1.41 KB 0644
gpio.h File 5.62 KB 0644
gsmmux.h File 1.02 KB 0644
gtp.h File 681 B 0644
hash_info.h File 921 B 0644
hdlc.h File 637 B 0644
hdlcdrv.h File 2.84 KB 0644
hdreg.h File 22.17 KB 0644
hid.h File 1.86 KB 0644
hiddev.h File 6.2 KB 0644
hidraw.h File 1.48 KB 0644
hpet.h File 743 B 0644
hsr_netlink.h File 1.06 KB 0644
hw_breakpoint.h File 742 B 0644
hyperv.h File 10.32 KB 0644
hysdn_if.h File 1.35 KB 0644
i2c-dev.h File 2.55 KB 0644
i2c.h File 6.96 KB 0644
i2o-dev.h File 11.28 KB 0644
i8k.h File 1.49 KB 0644
icmp.h File 2.91 KB 0644
icmpv6.h File 3.88 KB 0644
if.h File 10.56 KB 0644
if_addr.h File 1.76 KB 0644
if_addrlabel.h File 721 B 0644
if_alg.h File 1.5 KB 0644
if_arcnet.h File 3.63 KB 0644
if_arp.h File 6.42 KB 0644
if_bonding.h File 4.17 KB 0644
if_bridge.h File 6.55 KB 0644
if_cablemodem.h File 986 B 0644
if_eql.h File 1.32 KB 0644
if_ether.h File 7.75 KB 0644
if_fc.h File 1.7 KB 0644
if_fddi.h File 3.66 KB 0644
if_frad.h File 2.95 KB 0644
if_hippi.h File 4.14 KB 0644
if_infiniband.h File 1.22 KB 0644
if_link.h File 21.44 KB 0644
if_ltalk.h File 210 B 0644
if_macsec.h File 5.48 KB 0644
if_packet.h File 7.73 KB 0644
if_phonet.h File 424 B 0644
if_plip.h File 660 B 0644
if_ppp.h File 29 B 0644
if_pppol2tp.h File 3.21 KB 0644
if_pppox.h File 4.76 KB 0644
if_slip.h File 872 B 0644
if_team.h File 2.54 KB 0644
if_tun.h File 3.88 KB 0644
if_tunnel.h File 3.91 KB 0644
if_vlan.h File 1.75 KB 0644
if_x25.h File 881 B 0644
ife.h File 351 B 0644
igmp.h File 2.94 KB 0644
ila.h File 1.2 KB 0644
in.h File 9.6 KB 0644
in6.h File 7.26 KB 0644
in_route.h File 936 B 0644
inet_diag.h File 4.23 KB 0644
inotify.h File 2.91 KB 0644
input-event-codes.h File 24.11 KB 0644
input.h File 15.09 KB 0644
ioctl.h File 163 B 0644
ip.h File 4.59 KB 0644
ip6_tunnel.h File 1.91 KB 0644
ip_vs.h File 13.31 KB 0644
ipc.h File 2.05 KB 0644
ipmi.h File 15.86 KB 0644
ipmi_msgdefs.h File 4.43 KB 0644
ipsec.h File 947 B 0644
ipv6.h File 3.87 KB 0644
ipv6_route.h File 1.86 KB 0644
ipx.h File 2.29 KB 0644
irda.h File 7.38 KB 0644
irqnr.h File 104 B 0644
isdn.h File 5.64 KB 0644
isdn_divertif.h File 1.17 KB 0644
isdn_ppp.h File 1.88 KB 0644
isdnif.h File 2.31 KB 0644
iso_fs.h File 6.33 KB 0644
ivtv.h File 2.95 KB 0644
ivtvfb.h File 1.18 KB 0644
ixjuser.h File 24.59 KB 0644
jffs2.h File 6.85 KB 0644
joystick.h File 3.56 KB 0644
kcm.h File 822 B 0644
kcmp.h File 522 B 0644
kcov.h File 1.07 KB 0644
kd.h File 6.14 KB 0644
kdev_t.h File 383 B 0644
kernel-page-flags.h File 877 B 0644
kernel.h File 194 B 0644
kernelcapi.h File 1019 B 0644
kexec.h File 1.79 KB 0644
keyboard.h File 12.48 KB 0644
keyctl.h File 3.47 KB 0644
kfd_ioctl.h File 9.37 KB 0644
kvm.h File 40.18 KB 0644
kvm_para.h File 882 B 0644
l2tp.h File 5.5 KB 0644
libc-compat.h File 8.09 KB 0644
lightnvm.h File 4.76 KB 0644
limits.h File 937 B 0644
lirc.h File 4.94 KB 0644
llc.h File 3.09 KB 0644
loop.h File 2.46 KB 0644
lp.h File 3.78 KB 0644
lwtunnel.h File 1.24 KB 0644
magic.h File 3.32 KB 0644
major.h File 4.6 KB 0644
map_to_7segment.h File 7.08 KB 0644
matroxfb.h File 1.43 KB 0644
max2175.h File 1.01 KB 0644
mdio.h File 13.8 KB 0644
media-bus-format.h File 6.26 KB 0644
media.h File 12.24 KB 0644
mei.h File 4.7 KB 0644
membarrier.h File 4.12 KB 0644
memfd.h File 1.2 KB 0644
mempolicy.h File 2.1 KB 0644
meye.h File 2.47 KB 0644
mic_common.h File 6.37 KB 0644
mic_ioctl.h File 2.2 KB 0644
mii.h File 7.89 KB 0644
minix_fs.h File 2.07 KB 0644
mman.h File 1.21 KB 0644
mmtimer.h File 2.07 KB 0644
module.h File 255 B 0644
mpls.h File 2.25 KB 0644
mpls_iptunnel.h File 761 B 0644
mqueue.h File 2.15 KB 0644
mroute.h File 5.3 KB 0644
mroute6.h File 4.47 KB 0644
msdos_fs.h File 6.8 KB 0644
msg.h File 3.27 KB 0644
mtio.h File 7.98 KB 0644
n_r3964.h File 2.35 KB 0644
nbd-netlink.h File 2.32 KB 0644
nbd.h File 2.95 KB 0644
ncp.h File 5 KB 0644
ncp_fs.h File 3.34 KB 0644
ncp_mount.h File 2.12 KB 0644
ncp_no.h File 714 B 0644
ncsi.h File 3.79 KB 0644
ndctl.h File 7.98 KB 0644
neighbour.h File 4.24 KB 0644
net.h File 2.04 KB 0644
net_dropmon.h File 1.13 KB 0644
net_namespace.h File 672 B 0644
net_tstamp.h File 4.33 KB 0644
netconf.h File 589 B 0644
netdevice.h File 2.2 KB 0644
netfilter.h File 1.78 KB 0644
netfilter_arp.h File 444 B 0644
netfilter_bridge.h File 901 B 0644
netfilter_decnet.h File 1.89 KB 0644
netfilter_ipv4.h File 2.08 KB 0644
netfilter_ipv6.h File 2.1 KB 0644
netlink.h File 7.61 KB 0644
netlink_diag.h File 1.49 KB 0644
netrom.h File 807 B 0644
nfc.h File 10.97 KB 0644
nfs.h File 4.37 KB 0644
nfs2.h File 1.43 KB 0644
nfs3.h File 2.3 KB 0644
nfs4.h File 6.28 KB 0644
nfs4_mount.h File 1.89 KB 0644
nfs_fs.h File 1.57 KB 0644
nfs_idmap.h File 2.19 KB 0644
nfs_mount.h File 2.38 KB 0644
nfsacl.h File 668 B 0644
nilfs2_api.h File 7.41 KB 0644
nilfs2_ondisk.h File 17.66 KB 0644
nl80211.h File 228.77 KB 0644
nsfs.h File 639 B 0644
nubus.h File 8.37 KB 0644
nvme_ioctl.h File 1.61 KB 0644
nvram.h File 532 B 0644
omap3isp.h File 20.25 KB 0644
omapfb.h File 5.78 KB 0644
oom.h File 511 B 0644
openvswitch.h File 34.48 KB 0644
packet_diag.h File 1.63 KB 0644
param.h File 141 B 0644
parport.h File 3.56 KB 0644
patchkey.h File 892 B 0644
pci.h File 1.35 KB 0644
pci_regs.h File 53.44 KB 0644
pcitest.h File 579 B 0644
perf_event.h File 30.78 KB 0644
personality.h File 2.05 KB 0644
pfkeyv2.h File 10.32 KB 0644
pg.h File 2.29 KB 0644
phantom.h File 1.62 KB 0644
phonet.h File 4.57 KB 0644
pkt_cls.h File 11.72 KB 0644
pkt_sched.h File 20.86 KB 0644
pktcdvd.h File 2.62 KB 0644
pmu.h File 5.19 KB 0644
poll.h File 22 B 0644
posix_acl.h File 1.22 KB 0644
posix_acl_xattr.h File 1.09 KB 0644
posix_types.h File 1.07 KB 0644
ppdev.h File 3.14 KB 0644
ppp-comp.h File 2.47 KB 0644
ppp-ioctl.h File 5.35 KB 0644
ppp_defs.h File 4.99 KB 0644
pps.h File 4.62 KB 0644
pr.h File 1.05 KB 0644
prctl.h File 7.73 KB 0644
psample.h File 798 B 0644
psci.h File 3.96 KB 0644
ptp_clock.h File 4.75 KB 0644
ptrace.h File 3.26 KB 0644
qnx4_fs.h File 2.27 KB 0644
qnxtypes.h File 624 B 0644
qrtr.h File 893 B 0644
quota.h File 6.14 KB 0644
radeonfb.h File 360 B 0644
random.h File 1.38 KB 0644
raw.h File 365 B 0644
rds.h File 8.91 KB 0644
reboot.h File 1.31 KB 0644
reiserfs_fs.h File 775 B 0644
reiserfs_xattr.h File 533 B 0644
resource.h File 2.29 KB 0644
rfkill.h File 3.6 KB 0644
rio_cm_cdev.h File 3.17 KB 0644
rio_mport_cdev.h File 9.11 KB 0644
romfs_fs.h File 1.21 KB 0644
rose.h File 2.18 KB 0644
route.h File 2.28 KB 0644
rpmsg.h File 1002 B 0644
rtc.h File 3.92 KB 0644
rtnetlink.h File 17.57 KB 0644
rxrpc.h File 4.96 KB 0644
scc.h File 4.49 KB 0644
sched.h File 2.29 KB 0644
scif_ioctl.h File 6.23 KB 0644
screen_info.h File 2.42 KB 0644
sctp.h File 31.97 KB 0644
sdla.h File 2.77 KB 0644
seccomp.h File 2.2 KB 0644
securebits.h File 2.64 KB 0644
sed-opal.h File 3.2 KB 0644
seg6.h File 1.14 KB 0644
seg6_genl.h File 589 B 0644
seg6_hmac.h File 423 B 0644
seg6_iptunnel.h File 927 B 0644
seg6_local.h File 1.76 KB 0644
selinux_netlink.h File 1.17 KB 0644
sem.h File 2.95 KB 0644
serial.h File 3.34 KB 0644
serial_core.h File 6.1 KB 0644
serial_reg.h File 15.19 KB 0644
serio.h File 2.02 KB 0644
shm.h File 3.58 KB 0644
signal.h File 388 B 0644
signalfd.h File 1.13 KB 0644
smc.h File 780 B 0644
smc_diag.h File 2.21 KB 0644
smiapp.h File 1.03 KB 0644
snmp.h File 12.35 KB 0644
sock_diag.h File 727 B 0644
socket.h File 801 B 0644
sockios.h File 5.96 KB 0644
sonet.h File 2.24 KB 0644
sonypi.h File 5.18 KB 0644
sound.h File 1.21 KB 0644
soundcard.h File 44.96 KB 0644
stat.h File 5.96 KB 0644
stddef.h File 131 B 0644
stm.h File 1.58 KB 0644
string.h File 238 B 0644
suspend_ioctls.h File 1.4 KB 0644
swab.h File 6.78 KB 0644
switchtec_ioctl.h File 4.36 KB 0644
sync_file.h File 2.82 KB 0644
synclink.h File 8.77 KB 0644
sysctl.h File 25.57 KB 0644
sysinfo.h File 1.02 KB 0644
target_core_user.h File 3.68 KB 0644
taskstats.h File 6.89 KB 0644
tcp.h File 8.1 KB 0644
tcp_metrics.h File 1.51 KB 0644
tee.h File 10.99 KB 0644
telephony.h File 8.9 KB 0644
termios.h File 506 B 0644
thermal.h File 924 B 0644
time.h File 1.68 KB 0644
timerfd.h File 936 B 0644
times.h File 278 B 0644
timex.h File 6.25 KB 0644
tiocl.h File 1.69 KB 0644
tipc.h File 7.53 KB 0644
tipc_config.h File 14.43 KB 0644
tipc_netlink.h File 7.82 KB 0644
tls.h File 2.66 KB 0644
toshiba.h File 1.88 KB 0644
tty.h File 1.55 KB 0644
tty_flags.h File 4.42 KB 0644
types.h File 1.4 KB 0644
udf_fs_i.h File 697 B 0644
udp.h File 1.43 KB 0644
uhid.h File 4.54 KB 0644
uinput.h File 9.04 KB 0644
uio.h File 732 B 0644
uleds.h File 798 B 0644
ultrasound.h File 4.46 KB 0644
un.h File 384 B 0644
unistd.h File 220 B 0644
unix_diag.h File 1.22 KB 0644
usbdevice_fs.h File 6.77 KB 0644
usbip.h File 640 B 0644
userfaultfd.h File 6.65 KB 0644
userio.h File 1.48 KB 0644
utime.h File 215 B 0644
utsname.h File 669 B 0644
uuid.h File 1.35 KB 0644
uvcvideo.h File 1.67 KB 0644
v4l2-common.h File 4.08 KB 0644
v4l2-controls.h File 43.93 KB 0644
v4l2-dv-timings.h File 30.82 KB 0644
v4l2-mediabus.h File 4.98 KB 0644
v4l2-subdev.h File 5.95 KB 0644
version.h File 97 B 0644
veth.h File 224 B 0644
vfio.h File 25.42 KB 0644
vfio_ccw.h File 504 B 0644
vhost.h File 7.13 KB 0644
videodev2.h File 84 KB 0644
virtio_9p.h File 1.99 KB 0644
virtio_balloon.h File 3.71 KB 0644
virtio_blk.h File 5.19 KB 0644
virtio_config.h File 3.34 KB 0644
virtio_console.h File 3.06 KB 0644
virtio_crypto.h File 13.55 KB 0644
virtio_gpu.h File 7.84 KB 0644
virtio_ids.h File 2.37 KB 0644
virtio_input.h File 2.45 KB 0644
virtio_mmio.h File 4.48 KB 0644
virtio_net.h File 9.89 KB 0644
virtio_pci.h File 6.91 KB 0644
virtio_ring.h File 6.19 KB 0644
virtio_rng.h File 265 B 0644
virtio_scsi.h File 5.89 KB 0644
virtio_types.h File 2.1 KB 0644
virtio_vsock.h File 3.01 KB 0644
vm_sockets.h File 5.19 KB 0644
vm_sockets_diag.h File 963 B 0644
vsockmon.h File 1.84 KB 0644
vt.h File 2.99 KB 0644
vtpm_proxy.h File 1.68 KB 0644
wait.h File 663 B 0644
wanrouter.h File 453 B 0644
watchdog.h File 2.28 KB 0644
wimax.h File 8.17 KB 0644
wireless.h File 41.71 KB 0644
wmi.h File 1.84 KB 0644
x25.h File 3.48 KB 0644
xattr.h File 2.79 KB 0644
xfrm.h File 11.6 KB 0644
xilinx-v4l2-controls.h File 2.91 KB 0644
zorro.h File 3.22 KB 0644
zorro_ids.h File 29.26 KB 0644