projects
/
openwrt
/
staging
/
blogic.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
| inline |
side by side
(parent:
17fda38
)
revert "cpumask: don't perform while loop in cpumask_next_and()"
author
Andrew Morton
<
[email protected]
>
Thu, 18 Jun 2015 18:01:11 +0000
(11:01 -0700)
committer
Linus Torvalds
<
[email protected]
>
Fri, 19 Jun 2015 03:00:23 +0000
(17:00 -1000)
Revert commit
534b483a86e6
("cpumask: don't perform while loop in
cpumask_next_and()").
This was a minor optimization, but it puts a `struct cpumask' on the
stack, which consumes too much stack space.
Sergey Senozhatsky <
[email protected]
>
Reported-by: Peter Zijlstra <
[email protected]
>
Cc: Sergey Senozhatsky <
[email protected]
>
Cc: Tejun Heo <
[email protected]
>
Cc: "David S. Miller" <
[email protected]
>
Cc: Amir Vadai <
[email protected]
>
Signed-off-by: Andrew Morton <
[email protected]
>
Signed-off-by: Linus Torvalds <
[email protected]
>
lib/cpumask.c
patch
|
blob
|
history
diff --git
a/lib/cpumask.c
b/lib/cpumask.c
index 5f627084f2e998b2605016c311411d91f7016918..5a70f6196f577a071ae0a31e9da7fa0e1dd1bc68 100644
(file)
--- a/
lib/cpumask.c
+++ b/
lib/cpumask.c
@@
-16,11
+16,10
@@
int cpumask_next_and(int n, const struct cpumask *src1p,
const struct cpumask *src2p)
{
- struct cpumask tmp;
-
- if (cpumask_and(&tmp, src1p, src2p))
- return cpumask_next(n, &tmp);
- return nr_cpu_ids;
+ while ((n = cpumask_next(n, src1p)) < nr_cpu_ids)
+ if (cpumask_test_cpu(n, src2p))
+ break;
+ return n;
}
EXPORT_SYMBOL(cpumask_next_and);