aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--kernel/sched_fair.c24
1 files changed, 6 insertions, 18 deletions
diff --git a/kernel/sched_fair.c b/kernel/sched_fair.c
index 335faf06a561..74d47e65b9ea 100644
--- a/kernel/sched_fair.c
+++ b/kernel/sched_fair.c
@@ -111,18 +111,6 @@ extern struct sched_class fair_sched_class;
111 * CFS operations on generic schedulable entities: 111 * CFS operations on generic schedulable entities:
112 */ 112 */
113 113
114/* currently running entity (if any) on this cfs_rq */
115static inline struct sched_entity *cfs_rq_curr(struct cfs_rq *cfs_rq)
116{
117 return cfs_rq->curr;
118}
119
120static inline void
121set_cfs_rq_curr(struct cfs_rq *cfs_rq, struct sched_entity *se)
122{
123 cfs_rq->curr = se;
124}
125
126#ifdef CONFIG_FAIR_GROUP_SCHED 114#ifdef CONFIG_FAIR_GROUP_SCHED
127 115
128/* cpu runqueue to which this cfs_rq is attached */ 116/* cpu runqueue to which this cfs_rq is attached */
@@ -382,7 +370,7 @@ __update_curr(struct cfs_rq *cfs_rq, struct sched_entity *curr,
382 370
383static void update_curr(struct cfs_rq *cfs_rq) 371static void update_curr(struct cfs_rq *cfs_rq)
384{ 372{
385 struct sched_entity *curr = cfs_rq_curr(cfs_rq); 373 struct sched_entity *curr = cfs_rq->curr;
386 u64 now = rq_of(cfs_rq)->clock; 374 u64 now = rq_of(cfs_rq)->clock;
387 unsigned long delta_exec; 375 unsigned long delta_exec;
388 376
@@ -440,7 +428,7 @@ static void update_stats_enqueue(struct cfs_rq *cfs_rq, struct sched_entity *se)
440 * Are we enqueueing a waiting task? (for current tasks 428 * Are we enqueueing a waiting task? (for current tasks
441 * a dequeue/enqueue event is a NOP) 429 * a dequeue/enqueue event is a NOP)
442 */ 430 */
443 if (se != cfs_rq_curr(cfs_rq)) 431 if (se != cfs_rq->curr)
444 update_stats_wait_start(cfs_rq, se); 432 update_stats_wait_start(cfs_rq, se);
445 /* 433 /*
446 * Update the key: 434 * Update the key:
@@ -511,7 +499,7 @@ update_stats_dequeue(struct cfs_rq *cfs_rq, struct sched_entity *se)
511 * Mark the end of the wait period if dequeueing a 499 * Mark the end of the wait period if dequeueing a
512 * waiting task: 500 * waiting task:
513 */ 501 */
514 if (se != cfs_rq_curr(cfs_rq)) 502 if (se != cfs_rq->curr)
515 update_stats_wait_end(cfs_rq, se); 503 update_stats_wait_end(cfs_rq, se);
516} 504}
517 505
@@ -717,7 +705,7 @@ set_next_entity(struct cfs_rq *cfs_rq, struct sched_entity *se)
717 */ 705 */
718 update_stats_wait_end(cfs_rq, se); 706 update_stats_wait_end(cfs_rq, se);
719 update_stats_curr_start(cfs_rq, se); 707 update_stats_curr_start(cfs_rq, se);
720 set_cfs_rq_curr(cfs_rq, se); 708 cfs_rq->curr = se;
721#ifdef CONFIG_SCHEDSTATS 709#ifdef CONFIG_SCHEDSTATS
722 /* 710 /*
723 * Track our maximum slice length, if the CPU's load is at 711 * Track our maximum slice length, if the CPU's load is at
@@ -754,7 +742,7 @@ static void put_prev_entity(struct cfs_rq *cfs_rq, struct sched_entity *prev)
754 742
755 if (prev->on_rq) 743 if (prev->on_rq)
756 update_stats_wait_start(cfs_rq, prev); 744 update_stats_wait_start(cfs_rq, prev);
757 set_cfs_rq_curr(cfs_rq, NULL); 745 cfs_rq->curr = NULL;
758} 746}
759 747
760static void entity_tick(struct cfs_rq *cfs_rq, struct sched_entity *curr) 748static void entity_tick(struct cfs_rq *cfs_rq, struct sched_entity *curr)
@@ -1153,7 +1141,7 @@ static void task_tick_fair(struct rq *rq, struct task_struct *curr)
1153static void task_new_fair(struct rq *rq, struct task_struct *p) 1141static void task_new_fair(struct rq *rq, struct task_struct *p)
1154{ 1142{
1155 struct cfs_rq *cfs_rq = task_cfs_rq(p); 1143 struct cfs_rq *cfs_rq = task_cfs_rq(p);
1156 struct sched_entity *se = &p->se, *curr = cfs_rq_curr(cfs_rq); 1144 struct sched_entity *se = &p->se, *curr = cfs_rq->curr;
1157 1145
1158 sched_info_queued(p); 1146 sched_info_queued(p);
1159 1147