kernel_stat.h 2.4 KB
Newer Older
L
Linus Torvalds 已提交
1 2 3 4 5 6
#ifndef _LINUX_KERNEL_STAT_H
#define _LINUX_KERNEL_STAT_H

#include <linux/smp.h>
#include <linux/threads.h>
#include <linux/percpu.h>
I
Ingo Molnar 已提交
7
#include <linux/cpumask.h>
8
#include <asm/irq.h>
L
Linus Torvalds 已提交
9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25
#include <asm/cputime.h>

/*
 * 'kernel_stat.h' contains the definitions needed for doing
 * some kernel statistics (CPU usage, context switches ...),
 * used by rstatd/perfmeter
 */

struct cpu_usage_stat {
	cputime64_t user;
	cputime64_t nice;
	cputime64_t system;
	cputime64_t softirq;
	cputime64_t irq;
	cputime64_t idle;
	cputime64_t iowait;
	cputime64_t steal;
26
	cputime64_t guest;
L
Linus Torvalds 已提交
27 28 29 30
};

struct kernel_stat {
	struct cpu_usage_stat	cpustat;
31
#ifndef CONFIG_GENERIC_HARDIRQS
32 33
       unsigned int irqs[NR_IRQS];
#endif
L
Linus Torvalds 已提交
34 35 36 37 38 39 40 41 42 43
};

DECLARE_PER_CPU(struct kernel_stat, kstat);

#define kstat_cpu(cpu)	per_cpu(kstat, cpu)
/* Must have preemption disabled for this to be meaningful. */
#define kstat_this_cpu	__get_cpu_var(kstat)

extern unsigned long long nr_context_switches(void);

44
#ifndef CONFIG_GENERIC_HARDIRQS
45 46 47
#define kstat_irqs_this_cpu(irq) \
	(kstat_this_cpu.irqs[irq])

T
Thomas Gleixner 已提交
48
struct irq_desc;
49

T
Thomas Gleixner 已提交
50 51 52 53 54
static inline void kstat_incr_irqs_this_cpu(unsigned int irq,
					    struct irq_desc *desc)
{
	kstat_this_cpu.irqs[irq]++;
}
55

56 57 58 59
static inline unsigned int kstat_irqs_cpu(unsigned int irq, int cpu)
{
       return kstat_cpu(cpu).irqs[irq];
}
60
#else
Y
Yinghai Lu 已提交
61
#include <linux/irq.h>
62
extern unsigned int kstat_irqs_cpu(unsigned int irq, int cpu);
Y
Yinghai Lu 已提交
63 64 65 66 67
#define kstat_irqs_this_cpu(DESC) \
	((DESC)->kstat_irqs[smp_processor_id()])
#define kstat_incr_irqs_this_cpu(irqno, DESC) \
	((DESC)->kstat_irqs[smp_processor_id()]++)

68
#endif
69

L
Linus Torvalds 已提交
70 71 72
/*
 * Number of interrupts per specific IRQ source, since bootup
 */
73
static inline unsigned int kstat_irqs(unsigned int irq)
L
Linus Torvalds 已提交
74
{
75 76
	unsigned int sum = 0;
	int cpu;
L
Linus Torvalds 已提交
77

78
	for_each_possible_cpu(cpu)
79
		sum += kstat_irqs_cpu(irq, cpu);
L
Linus Torvalds 已提交
80 81 82 83

	return sum;
}

I
Ingo Molnar 已提交
84 85 86 87

/*
 * Lock/unlock the current runqueue - to extract task statistics:
 */
88
extern unsigned long long task_delta_exec(struct task_struct *);
I
Ingo Molnar 已提交
89

90 91
extern void account_user_time(struct task_struct *, cputime_t, cputime_t);
extern void account_system_time(struct task_struct *, int, cputime_t, cputime_t);
92 93 94 95 96 97
extern void account_steal_time(cputime_t);
extern void account_idle_time(cputime_t);

extern void account_process_tick(struct task_struct *, int user);
extern void account_steal_ticks(unsigned long ticks);
extern void account_idle_ticks(unsigned long ticks);
L
Linus Torvalds 已提交
98 99

#endif /* _LINUX_KERNEL_STAT_H */