提交 8a57fff0 编写于 作者: J Johannes Berg

regulatory: don't write past array when intersecting rules

When intersecting rules, we count first to know how many
rules need to be allocated, and then do the intersection
into the allocated array. However, the code doing this
writes past the end of the array because it attempts to
do all intersections. Make it stop when the right number
of rules has been reached.
Acked-by: NLuis R. Rodriguez <mcgrof@do-not-panic.com>
Signed-off-by: NJohannes Berg <johannes.berg@intel.com>
上级 10ff57f9
...@@ -647,9 +647,9 @@ static struct ieee80211_regdomain *regdom_intersect( ...@@ -647,9 +647,9 @@ static struct ieee80211_regdomain *regdom_intersect(
if (!rd) if (!rd)
return NULL; return NULL;
for (x = 0; x < rd1->n_reg_rules; x++) { for (x = 0; x < rd1->n_reg_rules && rule_idx < num_rules; x++) {
rule1 = &rd1->reg_rules[x]; rule1 = &rd1->reg_rules[x];
for (y = 0; y < rd2->n_reg_rules; y++) { for (y = 0; y < rd2->n_reg_rules && rule_idx < num_rules; y++) {
rule2 = &rd2->reg_rules[y]; rule2 = &rd2->reg_rules[y];
/* /*
* This time around instead of using the stack lets * This time around instead of using the stack lets
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册