diff options
| -rw-r--r-- | arch/i386/kernel/smpboot.c | 29 |
1 files changed, 5 insertions, 24 deletions
diff --git a/arch/i386/kernel/smpboot.c b/arch/i386/kernel/smpboot.c index 346f27f4c79f..b4e6f32de453 100644 --- a/arch/i386/kernel/smpboot.c +++ b/arch/i386/kernel/smpboot.c | |||
| @@ -1130,34 +1130,15 @@ exit: | |||
| 1130 | } | 1130 | } |
| 1131 | #endif | 1131 | #endif |
| 1132 | 1132 | ||
| 1133 | static void smp_tune_scheduling (void) | 1133 | static void smp_tune_scheduling(void) |
| 1134 | { | 1134 | { |
| 1135 | unsigned long cachesize; /* kB */ | 1135 | unsigned long cachesize; /* kB */ |
| 1136 | unsigned long bandwidth = 350; /* MB/s */ | ||
| 1137 | /* | ||
| 1138 | * Rough estimation for SMP scheduling, this is the number of | ||
| 1139 | * cycles it takes for a fully memory-limited process to flush | ||
| 1140 | * the SMP-local cache. | ||
| 1141 | * | ||
| 1142 | * (For a P5 this pretty much means we will choose another idle | ||
| 1143 | * CPU almost always at wakeup time (this is due to the small | ||
| 1144 | * L1 cache), on PIIs it's around 50-100 usecs, depending on | ||
| 1145 | * the cache size) | ||
| 1146 | */ | ||
| 1147 | 1136 | ||
| 1148 | if (!cpu_khz) { | 1137 | if (cpu_khz) { |
| 1149 | /* | ||
| 1150 | * this basically disables processor-affinity | ||
| 1151 | * scheduling on SMP without a TSC. | ||
| 1152 | */ | ||
| 1153 | return; | ||
| 1154 | } else { | ||
| 1155 | cachesize = boot_cpu_data.x86_cache_size; | 1138 | cachesize = boot_cpu_data.x86_cache_size; |
| 1156 | if (cachesize == -1) { | 1139 | |
| 1157 | cachesize = 16; /* Pentiums, 2x8kB cache */ | 1140 | if (cachesize > 0) |
| 1158 | bandwidth = 100; | 1141 | max_cache_size = cachesize * 1024; |
| 1159 | } | ||
| 1160 | max_cache_size = cachesize * 1024; | ||
| 1161 | } | 1142 | } |
| 1162 | } | 1143 | } |
| 1163 | 1144 | ||
