kernel_stat.h 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. #ifndef _LINUX_KERNEL_STAT_H
  2. #define _LINUX_KERNEL_STAT_H
  3. #include <linux/smp.h>
  4. #include <linux/threads.h>
  5. #include <linux/percpu.h>
  6. #include <linux/cpumask.h>
  7. #include <linux/interrupt.h>
  8. #include <linux/sched.h>
  9. #include <linux/vtime.h>
  10. #include <asm/irq.h>
  11. #include <linux/cputime.h>
  12. /*
  13. * 'kernel_stat.h' contains the definitions needed for doing
  14. * some kernel statistics (CPU usage, context switches ...),
  15. * used by rstatd/perfmeter
  16. */
  17. enum cpu_usage_stat {
  18. CPUTIME_USER,
  19. CPUTIME_NICE,
  20. CPUTIME_SYSTEM,
  21. CPUTIME_SOFTIRQ,
  22. CPUTIME_IRQ,
  23. CPUTIME_IDLE,
  24. CPUTIME_IOWAIT,
  25. CPUTIME_STEAL,
  26. CPUTIME_GUEST,
  27. CPUTIME_GUEST_NICE,
  28. NR_STATS,
  29. };
  30. struct kernel_cpustat {
  31. u64 cpustat[NR_STATS];
  32. };
  33. struct kernel_stat {
  34. unsigned long irqs_sum;
  35. unsigned int softirqs[NR_SOFTIRQS];
  36. };
  37. DECLARE_PER_CPU(struct kernel_stat, kstat);
  38. DECLARE_PER_CPU(struct kernel_cpustat, kernel_cpustat);
  39. /* Must have preemption disabled for this to be meaningful. */
  40. #define kstat_this_cpu this_cpu_ptr(&kstat)
  41. #define kcpustat_this_cpu this_cpu_ptr(&kernel_cpustat)
  42. #define kstat_cpu(cpu) per_cpu(kstat, cpu)
  43. #define kcpustat_cpu(cpu) per_cpu(kernel_cpustat, cpu)
  44. extern unsigned long long nr_context_switches(void);
  45. extern unsigned int kstat_irqs_cpu(unsigned int irq, int cpu);
  46. extern void kstat_incr_irq_this_cpu(unsigned int irq);
  47. static inline void kstat_incr_softirqs_this_cpu(unsigned int irq)
  48. {
  49. __this_cpu_inc(kstat.softirqs[irq]);
  50. }
  51. static inline unsigned int kstat_softirqs_cpu(unsigned int irq, int cpu)
  52. {
  53. return kstat_cpu(cpu).softirqs[irq];
  54. }
  55. /*
  56. * Number of interrupts per specific IRQ source, since bootup
  57. */
  58. extern unsigned int kstat_irqs(unsigned int irq);
  59. extern unsigned int kstat_irqs_usr(unsigned int irq);
  60. /*
  61. * Number of interrupts per cpu, since bootup
  62. */
  63. static inline unsigned int kstat_cpu_irqs_sum(unsigned int cpu)
  64. {
  65. return kstat_cpu(cpu).irqs_sum;
  66. }
  67. extern void account_user_time(struct task_struct *, cputime_t, cputime_t);
  68. extern void account_system_time(struct task_struct *, int, cputime_t, cputime_t);
  69. extern void account_steal_time(cputime_t);
  70. extern void account_idle_time(cputime_t);
  71. #ifdef CONFIG_VIRT_CPU_ACCOUNTING_NATIVE
  72. static inline void account_process_tick(struct task_struct *tsk, int user)
  73. {
  74. vtime_account_user(tsk);
  75. }
  76. #else
  77. extern void account_process_tick(struct task_struct *, int user);
  78. #endif
  79. extern void account_idle_ticks(unsigned long ticks);
  80. #endif /* _LINUX_KERNEL_STAT_H */