This source file includes following definitions.
- ath5k_ani_set_noise_immunity_level
- ath5k_ani_set_spur_immunity_level
- ath5k_ani_set_firstep_level
- ath5k_ani_set_ofdm_weak_signal_detection
- ath5k_ani_set_cck_weak_signal_detection
- ath5k_ani_raise_immunity
- ath5k_ani_lower_immunity
- ath5k_hw_ani_get_listen_time
- ath5k_ani_save_and_clear_phy_errors
- ath5k_ani_period_restart
- ath5k_ani_calibration
- ath5k_ani_mib_intr
- ath5k_ani_phy_error_report
- ath5k_enable_phy_err_counters
- ath5k_disable_phy_err_counters
- ath5k_ani_init
- ath5k_ani_print_counters
   1 
   2 
   3 
   4 
   5 
   6 
   7 
   8 
   9 
  10 
  11 
  12 
  13 
  14 
  15 
  16 
  17 #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
  18 
  19 #include "ath5k.h"
  20 #include "reg.h"
  21 #include "debug.h"
  22 #include "ani.h"
  23 
  24 
  25 
  26 
  27 
  28 
  29 
  30 
  31 
  32 
  33 
  34 
  35 
  36 
  37 
  38 
  39 
  40 
  41 
  42 
  43 
  44 
  45 
  46 
  47 
  48 
  49 
  50 
  51 
  52 
  53 
  54 
  55 
  56 
  57 
  58 
  59 
  60 
  61 
  62 
  63 
  64 
  65 void
  66 ath5k_ani_set_noise_immunity_level(struct ath5k_hw *ah, int level)
  67 {
  68         
  69 
  70 
  71 
  72 
  73 
  74 #if 0
  75         static const s8 lo[] = { -52, -56, -60, -64, -70 };
  76         static const s8 hi[] = { -18, -18, -16, -14, -12 };
  77         static const s8 sz[] = { -34, -41, -48, -55, -62 };
  78         static const s8 fr[] = { -70, -72, -75, -78, -80 };
  79 #else
  80         static const s8 lo[] = { -64, -70 };
  81         static const s8 hi[] = { -14, -12 };
  82         static const s8 sz[] = { -55, -62 };
  83         static const s8 fr[] = { -78, -80 };
  84 #endif
  85         if (level < 0 || level >= ARRAY_SIZE(sz)) {
  86                 ATH5K_ERR(ah, "noise immunity level %d out of range",
  87                           level);
  88                 return;
  89         }
  90 
  91         AR5K_REG_WRITE_BITS(ah, AR5K_PHY_DESIRED_SIZE,
  92                                 AR5K_PHY_DESIRED_SIZE_TOT, sz[level]);
  93         AR5K_REG_WRITE_BITS(ah, AR5K_PHY_AGCCOARSE,
  94                                 AR5K_PHY_AGCCOARSE_LO, lo[level]);
  95         AR5K_REG_WRITE_BITS(ah, AR5K_PHY_AGCCOARSE,
  96                                 AR5K_PHY_AGCCOARSE_HI, hi[level]);
  97         AR5K_REG_WRITE_BITS(ah, AR5K_PHY_SIG,
  98                                 AR5K_PHY_SIG_FIRPWR, fr[level]);
  99 
 100         ah->ani_state.noise_imm_level = level;
 101         ATH5K_DBG_UNLIMIT(ah, ATH5K_DEBUG_ANI, "new level %d", level);
 102 }
 103 
 104 
 105 
 106 
 107 
 108 
 109 
 110 void
 111 ath5k_ani_set_spur_immunity_level(struct ath5k_hw *ah, int level)
 112 {
 113         static const int val[] = { 2, 4, 6, 8, 10, 12, 14, 16 };
 114 
 115         if (level < 0 || level >= ARRAY_SIZE(val) ||
 116             level > ah->ani_state.max_spur_level) {
 117                 ATH5K_ERR(ah, "spur immunity level %d out of range",
 118                           level);
 119                 return;
 120         }
 121 
 122         AR5K_REG_WRITE_BITS(ah, AR5K_PHY_OFDM_SELFCORR,
 123                 AR5K_PHY_OFDM_SELFCORR_CYPWR_THR1, val[level]);
 124 
 125         ah->ani_state.spur_level = level;
 126         ATH5K_DBG_UNLIMIT(ah, ATH5K_DEBUG_ANI, "new level %d", level);
 127 }
 128 
 129 
 130 
 131 
 132 
 133 
 134 void
 135 ath5k_ani_set_firstep_level(struct ath5k_hw *ah, int level)
 136 {
 137         static const int val[] = { 0, 4, 8 };
 138 
 139         if (level < 0 || level >= ARRAY_SIZE(val)) {
 140                 ATH5K_ERR(ah, "firstep level %d out of range", level);
 141                 return;
 142         }
 143 
 144         AR5K_REG_WRITE_BITS(ah, AR5K_PHY_SIG,
 145                                 AR5K_PHY_SIG_FIRSTEP, val[level]);
 146 
 147         ah->ani_state.firstep_level = level;
 148         ATH5K_DBG_UNLIMIT(ah, ATH5K_DEBUG_ANI, "new level %d", level);
 149 }
 150 
 151 
 152 
 153 
 154 
 155 
 156 void
 157 ath5k_ani_set_ofdm_weak_signal_detection(struct ath5k_hw *ah, bool on)
 158 {
 159         static const int m1l[] = { 127, 50 };
 160         static const int m2l[] = { 127, 40 };
 161         static const int m1[] = { 127, 0x4d };
 162         static const int m2[] = { 127, 0x40 };
 163         static const int m2cnt[] = { 31, 16 };
 164         static const int m2lcnt[] = { 63, 48 };
 165 
 166         AR5K_REG_WRITE_BITS(ah, AR5K_PHY_WEAK_OFDM_LOW_THR,
 167                                 AR5K_PHY_WEAK_OFDM_LOW_THR_M1, m1l[on]);
 168         AR5K_REG_WRITE_BITS(ah, AR5K_PHY_WEAK_OFDM_LOW_THR,
 169                                 AR5K_PHY_WEAK_OFDM_LOW_THR_M2, m2l[on]);
 170         AR5K_REG_WRITE_BITS(ah, AR5K_PHY_WEAK_OFDM_HIGH_THR,
 171                                 AR5K_PHY_WEAK_OFDM_HIGH_THR_M1, m1[on]);
 172         AR5K_REG_WRITE_BITS(ah, AR5K_PHY_WEAK_OFDM_HIGH_THR,
 173                                 AR5K_PHY_WEAK_OFDM_HIGH_THR_M2, m2[on]);
 174         AR5K_REG_WRITE_BITS(ah, AR5K_PHY_WEAK_OFDM_HIGH_THR,
 175                         AR5K_PHY_WEAK_OFDM_HIGH_THR_M2_COUNT, m2cnt[on]);
 176         AR5K_REG_WRITE_BITS(ah, AR5K_PHY_WEAK_OFDM_LOW_THR,
 177                         AR5K_PHY_WEAK_OFDM_LOW_THR_M2_COUNT, m2lcnt[on]);
 178 
 179         if (on)
 180                 AR5K_REG_ENABLE_BITS(ah, AR5K_PHY_WEAK_OFDM_LOW_THR,
 181                                 AR5K_PHY_WEAK_OFDM_LOW_THR_SELFCOR_EN);
 182         else
 183                 AR5K_REG_DISABLE_BITS(ah, AR5K_PHY_WEAK_OFDM_LOW_THR,
 184                                 AR5K_PHY_WEAK_OFDM_LOW_THR_SELFCOR_EN);
 185 
 186         ah->ani_state.ofdm_weak_sig = on;
 187         ATH5K_DBG_UNLIMIT(ah, ATH5K_DEBUG_ANI, "turned %s",
 188                           on ? "on" : "off");
 189 }
 190 
 191 
 192 
 193 
 194 
 195 
 196 void
 197 ath5k_ani_set_cck_weak_signal_detection(struct ath5k_hw *ah, bool on)
 198 {
 199         static const int val[] = { 8, 6 };
 200         AR5K_REG_WRITE_BITS(ah, AR5K_PHY_CCK_CROSSCORR,
 201                                 AR5K_PHY_CCK_CROSSCORR_WEAK_SIG_THR, val[on]);
 202         ah->ani_state.cck_weak_sig = on;
 203         ATH5K_DBG_UNLIMIT(ah, ATH5K_DEBUG_ANI, "turned %s",
 204                           on ? "on" : "off");
 205 }
 206 
 207 
 208 
 209 
 210 
 211 
 212 
 213 
 214 
 215 
 216 
 217 
 218 
 219 
 220 
 221 
 222 static void
 223 ath5k_ani_raise_immunity(struct ath5k_hw *ah, struct ath5k_ani_state *as,
 224                          bool ofdm_trigger)
 225 {
 226         int rssi = ewma_beacon_rssi_read(&ah->ah_beacon_rssi_avg);
 227 
 228         ATH5K_DBG_UNLIMIT(ah, ATH5K_DEBUG_ANI, "raise immunity (%s)",
 229                 ofdm_trigger ? "ODFM" : "CCK");
 230 
 231         
 232         if (as->noise_imm_level < ATH5K_ANI_MAX_NOISE_IMM_LVL) {
 233                 ath5k_ani_set_noise_immunity_level(ah, as->noise_imm_level + 1);
 234                 return;
 235         }
 236 
 237         
 238         if (ofdm_trigger &&
 239             as->spur_level < ah->ani_state.max_spur_level) {
 240                 ath5k_ani_set_spur_immunity_level(ah, as->spur_level + 1);
 241                 return;
 242         }
 243 
 244         
 245         if (ah->opmode == NL80211_IFTYPE_AP) {
 246                 if (as->firstep_level < ATH5K_ANI_MAX_FIRSTEP_LVL)
 247                         ath5k_ani_set_firstep_level(ah, as->firstep_level + 1);
 248                 return;
 249         }
 250 
 251         
 252 
 253         
 254 
 255 
 256 
 257         if (rssi > ATH5K_ANI_RSSI_THR_HIGH) {
 258                 ATH5K_DBG_UNLIMIT(ah, ATH5K_DEBUG_ANI,
 259                                   "beacon RSSI high");
 260                 
 261 
 262                 if (ofdm_trigger && as->ofdm_weak_sig) {
 263                         ath5k_ani_set_ofdm_weak_signal_detection(ah, false);
 264                         ath5k_ani_set_spur_immunity_level(ah, 0);
 265                         return;
 266                 }
 267                 
 268                 if (as->firstep_level < ATH5K_ANI_MAX_FIRSTEP_LVL) {
 269                         ath5k_ani_set_firstep_level(ah, as->firstep_level + 1);
 270                         return;
 271                 }
 272         } else if (rssi > ATH5K_ANI_RSSI_THR_LOW) {
 273                 
 274 
 275                 ATH5K_DBG_UNLIMIT(ah, ATH5K_DEBUG_ANI,
 276                                   "beacon RSSI mid");
 277                 if (ofdm_trigger && !as->ofdm_weak_sig)
 278                         ath5k_ani_set_ofdm_weak_signal_detection(ah, true);
 279                 if (as->firstep_level < ATH5K_ANI_MAX_FIRSTEP_LVL)
 280                         ath5k_ani_set_firstep_level(ah, as->firstep_level + 1);
 281                 return;
 282         } else if (ah->ah_current_channel->band == NL80211_BAND_2GHZ) {
 283                 
 284 
 285                 ATH5K_DBG_UNLIMIT(ah, ATH5K_DEBUG_ANI,
 286                                   "beacon RSSI low, 2GHz");
 287                 if (ofdm_trigger && as->ofdm_weak_sig)
 288                         ath5k_ani_set_ofdm_weak_signal_detection(ah, false);
 289                 if (as->firstep_level > 0)
 290                         ath5k_ani_set_firstep_level(ah, 0);
 291                 return;
 292         }
 293 
 294         
 295 
 296 
 297 
 298 
 299 }
 300 
 301 
 302 
 303 
 304 
 305 
 306 
 307 
 308 
 309 static void
 310 ath5k_ani_lower_immunity(struct ath5k_hw *ah, struct ath5k_ani_state *as)
 311 {
 312         int rssi = ewma_beacon_rssi_read(&ah->ah_beacon_rssi_avg);
 313 
 314         ATH5K_DBG_UNLIMIT(ah, ATH5K_DEBUG_ANI, "lower immunity");
 315 
 316         if (ah->opmode == NL80211_IFTYPE_AP) {
 317                 
 318                 if (as->firstep_level > 0) {
 319                         ath5k_ani_set_firstep_level(ah, as->firstep_level - 1);
 320                         return;
 321                 }
 322         } else {
 323                 
 324                 if (rssi > ATH5K_ANI_RSSI_THR_HIGH) {
 325                         
 326 
 327 
 328                 } else if (rssi > ATH5K_ANI_RSSI_THR_LOW) {
 329                         
 330 
 331                         if (!as->ofdm_weak_sig) {
 332                                 ath5k_ani_set_ofdm_weak_signal_detection(ah,
 333                                                                          true);
 334                                 return;
 335                         }
 336                         if (as->firstep_level > 0) {
 337                                 ath5k_ani_set_firstep_level(ah,
 338                                                         as->firstep_level - 1);
 339                                 return;
 340                         }
 341                 } else {
 342                         
 343                         if (as->firstep_level > 0) {
 344                                 ath5k_ani_set_firstep_level(ah,
 345                                                         as->firstep_level - 1);
 346                                 return;
 347                         }
 348                 }
 349         }
 350 
 351         
 352         if (as->spur_level > 0) {
 353                 ath5k_ani_set_spur_immunity_level(ah, as->spur_level - 1);
 354                 return;
 355         }
 356 
 357         
 358         if (as->noise_imm_level > 0) {
 359                 ath5k_ani_set_noise_immunity_level(ah, as->noise_imm_level - 1);
 360                 return;
 361         }
 362 }
 363 
 364 
 365 
 366 
 367 
 368 
 369 
 370 
 371 
 372 
 373 static int
 374 ath5k_hw_ani_get_listen_time(struct ath5k_hw *ah, struct ath5k_ani_state *as)
 375 {
 376         struct ath_common *common = ath5k_hw_common(ah);
 377         int listen;
 378 
 379         spin_lock_bh(&common->cc_lock);
 380 
 381         ath_hw_cycle_counters_update(common);
 382         memcpy(&as->last_cc, &common->cc_ani, sizeof(as->last_cc));
 383 
 384         
 385         listen = ath_hw_get_listen_time(common);
 386 
 387         spin_unlock_bh(&common->cc_lock);
 388 
 389         return listen;
 390 }
 391 
 392 
 393 
 394 
 395 
 396 
 397 
 398 
 399 
 400 
 401 
 402 
 403 
 404 
 405 static int
 406 ath5k_ani_save_and_clear_phy_errors(struct ath5k_hw *ah,
 407                                     struct ath5k_ani_state *as)
 408 {
 409         unsigned int ofdm_err, cck_err;
 410 
 411         if (!ah->ah_capabilities.cap_has_phyerr_counters)
 412                 return 0;
 413 
 414         ofdm_err = ath5k_hw_reg_read(ah, AR5K_PHYERR_CNT1);
 415         cck_err = ath5k_hw_reg_read(ah, AR5K_PHYERR_CNT2);
 416 
 417         
 418         ath5k_hw_reg_write(ah, ATH5K_PHYERR_CNT_MAX - ATH5K_ANI_OFDM_TRIG_HIGH,
 419                            AR5K_PHYERR_CNT1);
 420         ath5k_hw_reg_write(ah, ATH5K_PHYERR_CNT_MAX - ATH5K_ANI_CCK_TRIG_HIGH,
 421                            AR5K_PHYERR_CNT2);
 422 
 423         ofdm_err = ATH5K_ANI_OFDM_TRIG_HIGH - (ATH5K_PHYERR_CNT_MAX - ofdm_err);
 424         cck_err = ATH5K_ANI_CCK_TRIG_HIGH - (ATH5K_PHYERR_CNT_MAX - cck_err);
 425 
 426         
 427 
 428         if (ofdm_err <= 0 && cck_err <= 0)
 429                 return 0;
 430 
 431         
 432         if (ofdm_err > 0) {
 433                 as->ofdm_errors += ofdm_err;
 434                 as->sum_ofdm_errors += ofdm_err;
 435         }
 436         if (cck_err > 0) {
 437                 as->cck_errors += cck_err;
 438                 as->sum_cck_errors += cck_err;
 439         }
 440         return 1;
 441 }
 442 
 443 
 444 
 445 
 446 
 447 
 448 
 449 static void
 450 ath5k_ani_period_restart(struct ath5k_ani_state *as)
 451 {
 452         
 453         as->last_ofdm_errors = as->ofdm_errors;
 454         as->last_cck_errors = as->cck_errors;
 455         as->last_listen = as->listen_time;
 456 
 457         as->ofdm_errors = 0;
 458         as->cck_errors = 0;
 459         as->listen_time = 0;
 460 }
 461 
 462 
 463 
 464 
 465 
 466 
 467 
 468 
 469 
 470 
 471 
 472 
 473 
 474 void
 475 ath5k_ani_calibration(struct ath5k_hw *ah)
 476 {
 477         struct ath5k_ani_state *as = &ah->ani_state;
 478         int listen, ofdm_high, ofdm_low, cck_high, cck_low;
 479 
 480         
 481 
 482 
 483         listen = ath5k_hw_ani_get_listen_time(ah, as);
 484         as->listen_time += listen;
 485 
 486         if (as->ani_mode != ATH5K_ANI_MODE_AUTO)
 487                 return;
 488 
 489         ath5k_ani_save_and_clear_phy_errors(ah, as);
 490 
 491         ofdm_high = as->listen_time * ATH5K_ANI_OFDM_TRIG_HIGH / 1000;
 492         cck_high = as->listen_time * ATH5K_ANI_CCK_TRIG_HIGH / 1000;
 493         ofdm_low = as->listen_time * ATH5K_ANI_OFDM_TRIG_LOW / 1000;
 494         cck_low = as->listen_time * ATH5K_ANI_CCK_TRIG_LOW / 1000;
 495 
 496         ATH5K_DBG_UNLIMIT(ah, ATH5K_DEBUG_ANI,
 497                 "listen %d (now %d)", as->listen_time, listen);
 498         ATH5K_DBG_UNLIMIT(ah, ATH5K_DEBUG_ANI,
 499                 "check high ofdm %d/%d cck %d/%d",
 500                 as->ofdm_errors, ofdm_high, as->cck_errors, cck_high);
 501 
 502         if (as->ofdm_errors > ofdm_high || as->cck_errors > cck_high) {
 503                 
 504                 bool ofdm_flag = as->ofdm_errors > ofdm_high ? true : false;
 505                 ath5k_ani_raise_immunity(ah, as, ofdm_flag);
 506                 ath5k_ani_period_restart(as);
 507 
 508         } else if (as->listen_time > 5 * ATH5K_ANI_LISTEN_PERIOD) {
 509                 
 510 
 511                 ATH5K_DBG_UNLIMIT(ah, ATH5K_DEBUG_ANI,
 512                         "check low ofdm %d/%d cck %d/%d",
 513                         as->ofdm_errors, ofdm_low, as->cck_errors, cck_low);
 514 
 515                 if (as->ofdm_errors <= ofdm_low && as->cck_errors <= cck_low)
 516                         ath5k_ani_lower_immunity(ah, as);
 517 
 518                 ath5k_ani_period_restart(as);
 519         }
 520 }
 521 
 522 
 523 
 524 
 525 
 526 
 527 
 528 
 529 
 530 
 531 
 532 
 533 
 534 
 535 
 536 
 537 
 538 void
 539 ath5k_ani_mib_intr(struct ath5k_hw *ah)
 540 {
 541         struct ath5k_ani_state *as = &ah->ani_state;
 542 
 543         
 544 
 545         if (!ah->ah_capabilities.cap_has_phyerr_counters)
 546                 return;
 547 
 548         
 549         ath5k_hw_reg_write(ah, 0, AR5K_OFDM_FIL_CNT);
 550         ath5k_hw_reg_write(ah, 0, AR5K_CCK_FIL_CNT);
 551 
 552         if (ah->ani_state.ani_mode != ATH5K_ANI_MODE_AUTO)
 553                 return;
 554 
 555         
 556 
 557 
 558         if (ath5k_ani_save_and_clear_phy_errors(ah, as) == 0)
 559                 return;
 560 
 561         if (as->ofdm_errors > ATH5K_ANI_OFDM_TRIG_HIGH ||
 562             as->cck_errors > ATH5K_ANI_CCK_TRIG_HIGH)
 563                 tasklet_schedule(&ah->ani_tasklet);
 564 }
 565 
 566 
 567 
 568 
 569 
 570 
 571 
 572 
 573 
 574 
 575 void
 576 ath5k_ani_phy_error_report(struct ath5k_hw *ah,
 577                            enum ath5k_phy_error_code phyerr)
 578 {
 579         struct ath5k_ani_state *as = &ah->ani_state;
 580 
 581         if (phyerr == AR5K_RX_PHY_ERROR_OFDM_TIMING) {
 582                 as->ofdm_errors++;
 583                 if (as->ofdm_errors > ATH5K_ANI_OFDM_TRIG_HIGH)
 584                         tasklet_schedule(&ah->ani_tasklet);
 585         } else if (phyerr == AR5K_RX_PHY_ERROR_CCK_TIMING) {
 586                 as->cck_errors++;
 587                 if (as->cck_errors > ATH5K_ANI_CCK_TRIG_HIGH)
 588                         tasklet_schedule(&ah->ani_tasklet);
 589         }
 590 }
 591 
 592 
 593 
 594 
 595 
 596 
 597 
 598 
 599 
 600 
 601 
 602 
 603 static void
 604 ath5k_enable_phy_err_counters(struct ath5k_hw *ah)
 605 {
 606         ath5k_hw_reg_write(ah, ATH5K_PHYERR_CNT_MAX - ATH5K_ANI_OFDM_TRIG_HIGH,
 607                            AR5K_PHYERR_CNT1);
 608         ath5k_hw_reg_write(ah, ATH5K_PHYERR_CNT_MAX - ATH5K_ANI_CCK_TRIG_HIGH,
 609                            AR5K_PHYERR_CNT2);
 610         ath5k_hw_reg_write(ah, AR5K_PHY_ERR_FIL_OFDM, AR5K_PHYERR_CNT1_MASK);
 611         ath5k_hw_reg_write(ah, AR5K_PHY_ERR_FIL_CCK, AR5K_PHYERR_CNT2_MASK);
 612 
 613         
 614         ath5k_hw_reg_write(ah, 0, AR5K_OFDM_FIL_CNT);
 615         ath5k_hw_reg_write(ah, 0, AR5K_CCK_FIL_CNT);
 616 }
 617 
 618 
 619 
 620 
 621 
 622 
 623 
 624 static void
 625 ath5k_disable_phy_err_counters(struct ath5k_hw *ah)
 626 {
 627         ath5k_hw_reg_write(ah, 0, AR5K_PHYERR_CNT1);
 628         ath5k_hw_reg_write(ah, 0, AR5K_PHYERR_CNT2);
 629         ath5k_hw_reg_write(ah, 0, AR5K_PHYERR_CNT1_MASK);
 630         ath5k_hw_reg_write(ah, 0, AR5K_PHYERR_CNT2_MASK);
 631 
 632         
 633         ath5k_hw_reg_write(ah, 0, AR5K_OFDM_FIL_CNT);
 634         ath5k_hw_reg_write(ah, 0, AR5K_CCK_FIL_CNT);
 635 }
 636 
 637 
 638 
 639 
 640 
 641 
 642 
 643 
 644 void
 645 ath5k_ani_init(struct ath5k_hw *ah, enum ath5k_ani_mode mode)
 646 {
 647         
 648         if (ah->ah_version < AR5K_AR5212)
 649                 return;
 650 
 651         if (mode < ATH5K_ANI_MODE_OFF || mode > ATH5K_ANI_MODE_AUTO) {
 652                 ATH5K_ERR(ah, "ANI mode %d out of range", mode);
 653                 return;
 654         }
 655 
 656         
 657         memset(&ah->ani_state, 0, sizeof(ah->ani_state));
 658 
 659         
 660         if (ah->ah_mac_srev < AR5K_SREV_AR2414)
 661                 ah->ani_state.max_spur_level = 7;
 662         else
 663                 ah->ani_state.max_spur_level = 2;
 664 
 665         
 666         if (mode == ATH5K_ANI_MODE_OFF) {
 667                 ATH5K_DBG_UNLIMIT(ah, ATH5K_DEBUG_ANI, "ANI off\n");
 668         } else if (mode == ATH5K_ANI_MODE_MANUAL_LOW) {
 669                 ATH5K_DBG_UNLIMIT(ah, ATH5K_DEBUG_ANI,
 670                         "ANI manual low -> high sensitivity\n");
 671                 ath5k_ani_set_noise_immunity_level(ah, 0);
 672                 ath5k_ani_set_spur_immunity_level(ah, 0);
 673                 ath5k_ani_set_firstep_level(ah, 0);
 674                 ath5k_ani_set_ofdm_weak_signal_detection(ah, true);
 675                 ath5k_ani_set_cck_weak_signal_detection(ah, true);
 676         } else if (mode == ATH5K_ANI_MODE_MANUAL_HIGH) {
 677                 ATH5K_DBG_UNLIMIT(ah, ATH5K_DEBUG_ANI,
 678                         "ANI manual high -> low sensitivity\n");
 679                 ath5k_ani_set_noise_immunity_level(ah,
 680                                         ATH5K_ANI_MAX_NOISE_IMM_LVL);
 681                 ath5k_ani_set_spur_immunity_level(ah,
 682                                         ah->ani_state.max_spur_level);
 683                 ath5k_ani_set_firstep_level(ah, ATH5K_ANI_MAX_FIRSTEP_LVL);
 684                 ath5k_ani_set_ofdm_weak_signal_detection(ah, false);
 685                 ath5k_ani_set_cck_weak_signal_detection(ah, false);
 686         } else if (mode == ATH5K_ANI_MODE_AUTO) {
 687                 ATH5K_DBG_UNLIMIT(ah, ATH5K_DEBUG_ANI, "ANI auto\n");
 688                 ath5k_ani_set_noise_immunity_level(ah, 0);
 689                 ath5k_ani_set_spur_immunity_level(ah, 0);
 690                 ath5k_ani_set_firstep_level(ah, 0);
 691                 ath5k_ani_set_ofdm_weak_signal_detection(ah, true);
 692                 ath5k_ani_set_cck_weak_signal_detection(ah, false);
 693         }
 694 
 695         
 696 
 697 
 698 
 699         if (mode == ATH5K_ANI_MODE_AUTO) {
 700                 if (ah->ah_capabilities.cap_has_phyerr_counters)
 701                         ath5k_enable_phy_err_counters(ah);
 702                 else
 703                         ath5k_hw_set_rx_filter(ah, ath5k_hw_get_rx_filter(ah) |
 704                                                    AR5K_RX_FILTER_PHYERR);
 705         } else {
 706                 if (ah->ah_capabilities.cap_has_phyerr_counters)
 707                         ath5k_disable_phy_err_counters(ah);
 708                 else
 709                         ath5k_hw_set_rx_filter(ah, ath5k_hw_get_rx_filter(ah) &
 710                                                    ~AR5K_RX_FILTER_PHYERR);
 711         }
 712 
 713         ah->ani_state.ani_mode = mode;
 714 }
 715 
 716 
 717 
 718 
 719 
 720 
 721 #ifdef CONFIG_ATH5K_DEBUG
 722 
 723 
 724 
 725 
 726 
 727 
 728 
 729 void
 730 ath5k_ani_print_counters(struct ath5k_hw *ah)
 731 {
 732         
 733         pr_notice("ACK fail\t%d\n", ath5k_hw_reg_read(ah, AR5K_ACK_FAIL));
 734         pr_notice("RTS fail\t%d\n", ath5k_hw_reg_read(ah, AR5K_RTS_FAIL));
 735         pr_notice("RTS success\t%d\n", ath5k_hw_reg_read(ah, AR5K_RTS_OK));
 736         pr_notice("FCS error\t%d\n", ath5k_hw_reg_read(ah, AR5K_FCS_FAIL));
 737 
 738         
 739         pr_notice("tx\t%d\n", ath5k_hw_reg_read(ah, AR5K_PROFCNT_TX));
 740         pr_notice("rx\t%d\n", ath5k_hw_reg_read(ah, AR5K_PROFCNT_RX));
 741         pr_notice("busy\t%d\n", ath5k_hw_reg_read(ah, AR5K_PROFCNT_RXCLR));
 742         pr_notice("cycles\t%d\n", ath5k_hw_reg_read(ah, AR5K_PROFCNT_CYCLE));
 743 
 744         pr_notice("AR5K_PHYERR_CNT1\t%d\n",
 745                   ath5k_hw_reg_read(ah, AR5K_PHYERR_CNT1));
 746         pr_notice("AR5K_PHYERR_CNT2\t%d\n",
 747                   ath5k_hw_reg_read(ah, AR5K_PHYERR_CNT2));
 748         pr_notice("AR5K_OFDM_FIL_CNT\t%d\n",
 749                   ath5k_hw_reg_read(ah, AR5K_OFDM_FIL_CNT));
 750         pr_notice("AR5K_CCK_FIL_CNT\t%d\n",
 751                   ath5k_hw_reg_read(ah, AR5K_CCK_FIL_CNT));
 752 }
 753 
 754 #endif