aboutsummaryrefslogtreecommitdiffstats
path: root/net/wireless
diff options
context:
space:
mode:
Diffstat (limited to 'net/wireless')
-rw-r--r--net/wireless/reg.c126
1 files changed, 63 insertions, 63 deletions
diff --git a/net/wireless/reg.c b/net/wireless/reg.c
index a20dd13c7094..9dff716d1b02 100644
--- a/net/wireless/reg.c
+++ b/net/wireless/reg.c
@@ -298,69 +298,6 @@ static int call_crda(const char *alpha2)
298 return kobject_uevent_env(&reg_pdev->dev.kobj, KOBJ_CHANGE, envp); 298 return kobject_uevent_env(&reg_pdev->dev.kobj, KOBJ_CHANGE, envp);
299} 299}
300 300
301/* This has the logic which determines when a new request
302 * should be ignored. */
303static int ignore_request(struct wiphy *wiphy, enum reg_set_by set_by,
304 const char *alpha2)
305{
306 /* All initial requests are respected */
307 if (!last_request)
308 return 0;
309
310 switch (set_by) {
311 case REGDOM_SET_BY_INIT:
312 return -EINVAL;
313 case REGDOM_SET_BY_CORE:
314 /*
315 * Always respect new wireless core hints, should only happen
316 * when updating the world regulatory domain at init.
317 */
318 return 0;
319 case REGDOM_SET_BY_COUNTRY_IE:
320 if (unlikely(!is_an_alpha2(alpha2)))
321 return -EINVAL;
322 if (last_request->initiator == REGDOM_SET_BY_COUNTRY_IE) {
323 if (last_request->wiphy != wiphy) {
324 /*
325 * Two cards with two APs claiming different
326 * different Country IE alpha2s. We could
327 * intersect them, but that seems unlikely
328 * to be correct. Reject second one for now.
329 */
330 if (!alpha2_equal(alpha2,
331 cfg80211_regdomain->alpha2))
332 return -EOPNOTSUPP;
333 return -EALREADY;
334 }
335 /* Two consecutive Country IE hints on the same wiphy */
336 if (!alpha2_equal(cfg80211_regdomain->alpha2, alpha2))
337 return 0;
338 return -EALREADY;
339 }
340 /*
341 * Ignore Country IE hints for now, need to think about
342 * what we need to do to support multi-domain operation.
343 */
344 return -EOPNOTSUPP;
345 case REGDOM_SET_BY_DRIVER:
346 if (last_request->initiator == REGDOM_SET_BY_DRIVER)
347 return -EALREADY;
348 return 0;
349 case REGDOM_SET_BY_USER:
350 /*
351 * If the user wants to override the AP's hint, we may
352 * need to follow both and use the intersection. For now,
353 * reject any such attempt (but we don't support country
354 * IEs right now anyway.)
355 */
356 if (last_request->initiator == REGDOM_SET_BY_COUNTRY_IE)
357 return -EOPNOTSUPP;
358 return 0;
359 }
360
361 return -EINVAL;
362}
363
364/* Used by nl80211 before kmalloc'ing our regulatory domain */ 301/* Used by nl80211 before kmalloc'ing our regulatory domain */
365bool reg_is_valid_request(const char *alpha2) 302bool reg_is_valid_request(const char *alpha2)
366{ 303{
@@ -531,6 +468,69 @@ void wiphy_update_regulatory(struct wiphy *wiphy, enum reg_set_by setby)
531 } 468 }
532} 469}
533 470
471/* This has the logic which determines when a new request
472 * should be ignored. */
473static int ignore_request(struct wiphy *wiphy, enum reg_set_by set_by,
474 const char *alpha2)
475{
476 /* All initial requests are respected */
477 if (!last_request)
478 return 0;
479
480 switch (set_by) {
481 case REGDOM_SET_BY_INIT:
482 return -EINVAL;
483 case REGDOM_SET_BY_CORE:
484 /*
485 * Always respect new wireless core hints, should only happen
486 * when updating the world regulatory domain at init.
487 */
488 return 0;
489 case REGDOM_SET_BY_COUNTRY_IE:
490 if (unlikely(!is_an_alpha2(alpha2)))
491 return -EINVAL;
492 if (last_request->initiator == REGDOM_SET_BY_COUNTRY_IE) {
493 if (last_request->wiphy != wiphy) {
494 /*
495 * Two cards with two APs claiming different
496 * different Country IE alpha2s. We could
497 * intersect them, but that seems unlikely
498 * to be correct. Reject second one for now.
499 */
500 if (!alpha2_equal(alpha2,
501 cfg80211_regdomain->alpha2))
502 return -EOPNOTSUPP;
503 return -EALREADY;
504 }
505 /* Two consecutive Country IE hints on the same wiphy */
506 if (!alpha2_equal(cfg80211_regdomain->alpha2, alpha2))
507 return 0;
508 return -EALREADY;
509 }
510 /*
511 * Ignore Country IE hints for now, need to think about
512 * what we need to do to support multi-domain operation.
513 */
514 return -EOPNOTSUPP;
515 case REGDOM_SET_BY_DRIVER:
516 if (last_request->initiator == REGDOM_SET_BY_DRIVER)
517 return -EALREADY;
518 return 0;
519 case REGDOM_SET_BY_USER:
520 /*
521 * If the user wants to override the AP's hint, we may
522 * need to follow both and use the intersection. For now,
523 * reject any such attempt (but we don't support country
524 * IEs right now anyway.)
525 */
526 if (last_request->initiator == REGDOM_SET_BY_COUNTRY_IE)
527 return -EOPNOTSUPP;
528 return 0;
529 }
530
531 return -EINVAL;
532}
533
534/* Caller must hold &cfg80211_drv_mutex */ 534/* Caller must hold &cfg80211_drv_mutex */
535int __regulatory_hint(struct wiphy *wiphy, enum reg_set_by set_by, 535int __regulatory_hint(struct wiphy *wiphy, enum reg_set_by set_by,
536 const char *alpha2) 536 const char *alpha2)