]> git.saurik.com Git - apple/xnu.git/blobdiff - osfmk/kern/processor_data.h
xnu-1699.22.73.tar.gz
[apple/xnu.git] / osfmk / kern / processor_data.h
index 200ec35f3a6681406f88f35471f48e614c010b2f..eda5bcce590b5876ca453d784fd25bbd640d6b86 100644 (file)
 #include <ipc/ipc_kmsg.h>
 #include <kern/timer.h>
 
+struct processor_sched_statistics {
+       uint32_t                csw_count;
+       uint32_t                preempt_count;
+       uint32_t                preempted_rt_count;
+       uint32_t                preempted_by_rt_count;
+       uint32_t                rt_sched_count;
+       uint32_t                interrupt_count;
+       uint32_t                ipi_count;
+       uint32_t                timer_pop_count;
+       uint32_t                idle_transitions;
+};
+
 struct processor_data {
        /* Processor state statistics */
        timer_data_t                    idle_state;
@@ -72,6 +84,8 @@ struct processor_data {
        unsigned long                   page_grab_count;
        int                                             start_color;
        void                                    *free_pages;
+
+       struct processor_sched_statistics sched_stats;
 };
 
 typedef struct processor_data  processor_data_t;
@@ -82,6 +96,34 @@ typedef struct processor_data        processor_data_t;
 extern void    processor_data_init(
                                        processor_t             processor);
 
+#define SCHED_STATS_INTERRUPT(p)                                       \
+MACRO_BEGIN                                                            \
+       if (__builtin_expect(sched_stats_active, 0)) {          \
+               (p)->processor_data.sched_stats.interrupt_count++;      \
+       }                                                               \
+MACRO_END      
+
+#define SCHED_STATS_TIMER_POP(p)                                       \
+MACRO_BEGIN                                                            \
+       if (__builtin_expect(sched_stats_active, 0)) {          \
+               (p)->processor_data.sched_stats.timer_pop_count++;      \
+       }                                                               \
+MACRO_END
+
+#define SCHED_STATS_IPI(p)                                             \
+MACRO_BEGIN                                                            \
+       if (__builtin_expect(sched_stats_active, 0)) {          \
+               (p)->processor_data.sched_stats.ipi_count++;            \
+       }                                                               \
+MACRO_END
+
+#define SCHED_STATS_CPU_IDLE_START(p)                                                          \
+MACRO_BEGIN                                                                                    \
+       if (__builtin_expect(sched_stats_active, 0)) {                                  \
+               (p)->processor_data.sched_stats.idle_transitions++;                             \
+       }                                                                                       \
+MACRO_END
+
 #endif /* MACH_KERNEL_PRIVATE */
 
 #endif /* _KERN_PROCESSOR_DATA_H_ */