Author: adrian
Date: Thu Aug 12 06:08:36 2010
New Revision: 211207
URL: http://svn.freebsd.org/changeset/base/211207

Log:
  Internal NF calibration should not occur in parallel with any other
  calibration. Ensure that the NF calibration completes before continuing
  with the rest of the calibration setup process.

Modified:
  head/sys/dev/ath/ath_hal/ar5416/ar5416_cal.c

Modified: head/sys/dev/ath/ath_hal/ar5416/ar5416_cal.c
==============================================================================
--- head/sys/dev/ath/ath_hal/ar5416/ar5416_cal.c        Thu Aug 12 06:06:14 
2010        (r211206)
+++ head/sys/dev/ath/ath_hal/ar5416/ar5416_cal.c        Thu Aug 12 06:08:36 
2010        (r211207)
@@ -24,6 +24,8 @@
 
 #include "ah_eeprom_v14.h"
 
+#include "ar5212/ar5212.h"     /* for NF cal related declarations */
+
 #include "ar5416/ar5416.h"
 #include "ar5416/ar5416reg.h"
 #include "ar5416/ar5416phy.h"
@@ -220,7 +222,16 @@ ar5416InitCal(struct ath_hal *ah, const 
         * triggered at the same time.
         */
        OS_REG_SET_BIT(ah, AR_PHY_AGC_CONTROL, AR_PHY_AGC_CONTROL_NF);
-
+       /*
+        * Try to make sure the above NF cal completes, just so
+        * it doesn't clash with subsequent percals -adrian
+       */
+       if (! ar5212WaitNFCalComplete(ah, 10000)) {
+               HALDEBUG(ah, HAL_DEBUG_ANY, "%s: initial NF calibration did "
+                   "not complete in time; noisy environment?\n", __func__);
+               return AH_FALSE;
+       }
+        
        /* Initialize list pointers */
        cal->cal_list = cal->cal_last = cal->cal_curr = AH_NULL;
 
_______________________________________________
svn-src-all@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-all
To unsubscribe, send any mail to "svn-src-all-unsubscr...@freebsd.org"

Reply via email to