diff options
author | Li Zefan <lizefan@huawei.com> | 2013-03-05 03:06:09 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@kernel.org> | 2013-03-06 05:24:30 -0500 |
commit | cc1f4b1f3faed9f2040eff2a75f510b424b3cf18 (patch) | |
tree | c894d67bfca2ff5aebf09cc1f3cc8b0f8f88ddd6 /kernel | |
parent | 090b582f27ac7b6714661020033160130e5297bd (diff) |
sched: Move SCHED_LOAD_SHIFT macros to kernel/sched/sched.h
They are used internally only.
Signed-off-by: Li Zefan <lizefan@huawei.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/5135A771.4070104@huawei.com
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'kernel')
-rw-r--r-- | kernel/sched/sched.h | 26 |
1 files changed, 25 insertions, 1 deletions
diff --git a/kernel/sched/sched.h b/kernel/sched/sched.h index cc03cfdf469f..709a30cdfd85 100644 --- a/kernel/sched/sched.h +++ b/kernel/sched/sched.h | |||
@@ -33,6 +33,31 @@ extern __read_mostly int scheduler_running; | |||
33 | */ | 33 | */ |
34 | #define NS_TO_JIFFIES(TIME) ((unsigned long)(TIME) / (NSEC_PER_SEC / HZ)) | 34 | #define NS_TO_JIFFIES(TIME) ((unsigned long)(TIME) / (NSEC_PER_SEC / HZ)) |
35 | 35 | ||
36 | /* | ||
37 | * Increase resolution of nice-level calculations for 64-bit architectures. | ||
38 | * The extra resolution improves shares distribution and load balancing of | ||
39 | * low-weight task groups (eg. nice +19 on an autogroup), deeper taskgroup | ||
40 | * hierarchies, especially on larger systems. This is not a user-visible change | ||
41 | * and does not change the user-interface for setting shares/weights. | ||
42 | * | ||
43 | * We increase resolution only if we have enough bits to allow this increased | ||
44 | * resolution (i.e. BITS_PER_LONG > 32). The costs for increasing resolution | ||
45 | * when BITS_PER_LONG <= 32 are pretty high and the returns do not justify the | ||
46 | * increased costs. | ||
47 | */ | ||
48 | #if 0 /* BITS_PER_LONG > 32 -- currently broken: it increases power usage under light load */ | ||
49 | # define SCHED_LOAD_RESOLUTION 10 | ||
50 | # define scale_load(w) ((w) << SCHED_LOAD_RESOLUTION) | ||
51 | # define scale_load_down(w) ((w) >> SCHED_LOAD_RESOLUTION) | ||
52 | #else | ||
53 | # define SCHED_LOAD_RESOLUTION 0 | ||
54 | # define scale_load(w) (w) | ||
55 | # define scale_load_down(w) (w) | ||
56 | #endif | ||
57 | |||
58 | #define SCHED_LOAD_SHIFT (10 + SCHED_LOAD_RESOLUTION) | ||
59 | #define SCHED_LOAD_SCALE (1L << SCHED_LOAD_SHIFT) | ||
60 | |||
36 | #define NICE_0_LOAD SCHED_LOAD_SCALE | 61 | #define NICE_0_LOAD SCHED_LOAD_SCALE |
37 | #define NICE_0_SHIFT SCHED_LOAD_SHIFT | 62 | #define NICE_0_SHIFT SCHED_LOAD_SHIFT |
38 | 63 | ||
@@ -784,7 +809,6 @@ static inline void finish_lock_switch(struct rq *rq, struct task_struct *prev) | |||
784 | } | 809 | } |
785 | #endif /* __ARCH_WANT_UNLOCKED_CTXSW */ | 810 | #endif /* __ARCH_WANT_UNLOCKED_CTXSW */ |
786 | 811 | ||
787 | |||
788 | static inline void update_load_add(struct load_weight *lw, unsigned long inc) | 812 | static inline void update_load_add(struct load_weight *lw, unsigned long inc) |
789 | { | 813 | { |
790 | lw->weight += inc; | 814 | lw->weight += inc; |