diff options
Diffstat (limited to 'kernel/sched.c')
-rw-r--r-- | kernel/sched.c | 56 |
1 files changed, 39 insertions, 17 deletions
diff --git a/kernel/sched.c b/kernel/sched.c index 88215066efae..41b7e2d524d6 100644 --- a/kernel/sched.c +++ b/kernel/sched.c | |||
@@ -9275,6 +9275,41 @@ cpuacct_destroy(struct cgroup_subsys *ss, struct cgroup *cgrp) | |||
9275 | kfree(ca); | 9275 | kfree(ca); |
9276 | } | 9276 | } |
9277 | 9277 | ||
9278 | static u64 cpuacct_cpuusage_read(struct cpuacct *ca, int cpu) | ||
9279 | { | ||
9280 | u64 *cpuusage = percpu_ptr(ca->cpuusage, cpu); | ||
9281 | u64 data; | ||
9282 | |||
9283 | #ifndef CONFIG_64BIT | ||
9284 | /* | ||
9285 | * Take rq->lock to make 64-bit read safe on 32-bit platforms. | ||
9286 | */ | ||
9287 | spin_lock_irq(&cpu_rq(cpu)->lock); | ||
9288 | data = *cpuusage; | ||
9289 | spin_unlock_irq(&cpu_rq(cpu)->lock); | ||
9290 | #else | ||
9291 | data = *cpuusage; | ||
9292 | #endif | ||
9293 | |||
9294 | return data; | ||
9295 | } | ||
9296 | |||
9297 | static void cpuacct_cpuusage_write(struct cpuacct *ca, int cpu, u64 val) | ||
9298 | { | ||
9299 | u64 *cpuusage = percpu_ptr(ca->cpuusage, cpu); | ||
9300 | |||
9301 | #ifndef CONFIG_64BIT | ||
9302 | /* | ||
9303 | * Take rq->lock to make 64-bit write safe on 32-bit platforms. | ||
9304 | */ | ||
9305 | spin_lock_irq(&cpu_rq(cpu)->lock); | ||
9306 | *cpuusage = val; | ||
9307 | spin_unlock_irq(&cpu_rq(cpu)->lock); | ||
9308 | #else | ||
9309 | *cpuusage = val; | ||
9310 | #endif | ||
9311 | } | ||
9312 | |||
9278 | /* return total cpu usage (in nanoseconds) of a group */ | 9313 | /* return total cpu usage (in nanoseconds) of a group */ |
9279 | static u64 cpuusage_read(struct cgroup *cgrp, struct cftype *cft) | 9314 | static u64 cpuusage_read(struct cgroup *cgrp, struct cftype *cft) |
9280 | { | 9315 | { |
@@ -9282,17 +9317,8 @@ static u64 cpuusage_read(struct cgroup *cgrp, struct cftype *cft) | |||
9282 | u64 totalcpuusage = 0; | 9317 | u64 totalcpuusage = 0; |
9283 | int i; | 9318 | int i; |
9284 | 9319 | ||
9285 | for_each_possible_cpu(i) { | 9320 | for_each_present_cpu(i) |
9286 | u64 *cpuusage = percpu_ptr(ca->cpuusage, i); | 9321 | totalcpuusage += cpuacct_cpuusage_read(ca, i); |
9287 | |||
9288 | /* | ||
9289 | * Take rq->lock to make 64-bit addition safe on 32-bit | ||
9290 | * platforms. | ||
9291 | */ | ||
9292 | spin_lock_irq(&cpu_rq(i)->lock); | ||
9293 | totalcpuusage += *cpuusage; | ||
9294 | spin_unlock_irq(&cpu_rq(i)->lock); | ||
9295 | } | ||
9296 | 9322 | ||
9297 | return totalcpuusage; | 9323 | return totalcpuusage; |
9298 | } | 9324 | } |
@@ -9309,13 +9335,9 @@ static int cpuusage_write(struct cgroup *cgrp, struct cftype *cftype, | |||
9309 | goto out; | 9335 | goto out; |
9310 | } | 9336 | } |
9311 | 9337 | ||
9312 | for_each_possible_cpu(i) { | 9338 | for_each_present_cpu(i) |
9313 | u64 *cpuusage = percpu_ptr(ca->cpuusage, i); | 9339 | cpuacct_cpuusage_write(ca, i, 0); |
9314 | 9340 | ||
9315 | spin_lock_irq(&cpu_rq(i)->lock); | ||
9316 | *cpuusage = 0; | ||
9317 | spin_unlock_irq(&cpu_rq(i)->lock); | ||
9318 | } | ||
9319 | out: | 9341 | out: |
9320 | return err; | 9342 | return err; |
9321 | } | 9343 | } |