From owner-svn-src-head@FreeBSD.ORG Thu Mar 3 08:38:32 2011 Return-Path: Delivered-To: svn-src-head@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 096DD106564A; Thu, 3 Mar 2011 08:38:32 +0000 (UTC) (envelope-from adrian@FreeBSD.org) Received: from svn.freebsd.org (svn.freebsd.org [IPv6:2001:4f8:fff6::2c]) by mx1.freebsd.org (Postfix) with ESMTP id EB8AC8FC14; Thu, 3 Mar 2011 08:38:31 +0000 (UTC) Received: from svn.freebsd.org (localhost [127.0.0.1]) by svn.freebsd.org (8.14.3/8.14.3) with ESMTP id p238cVNl012003; Thu, 3 Mar 2011 08:38:31 GMT (envelope-from adrian@svn.freebsd.org) Received: (from adrian@localhost) by svn.freebsd.org (8.14.3/8.14.3/Submit) id p238cVat011999; Thu, 3 Mar 2011 08:38:31 GMT (envelope-from adrian@svn.freebsd.org) Message-Id: <201103030838.p238cVat011999@svn.freebsd.org> From: Adrian Chadd Date: Thu, 3 Mar 2011 08:38:31 +0000 (UTC) To: src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org X-SVN-Group: head MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Cc: Subject: svn commit: r219218 - in head/sys/dev/ath/ath_hal: ar5416 ar9002 X-BeenThere: svn-src-head@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: SVN commit messages for the src tree for head/-current List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Thu, 03 Mar 2011 08:38:32 -0000 Author: adrian Date: Thu Mar 3 08:38:31 2011 New Revision: 219218 URL: http://svn.freebsd.org/changeset/base/219218 Log: Port over ar5416OverrideIni() from ath9k ar5008_hw_override_ini(). * change the BB gating logic to explicitly define which chips are covered; the ath9k method isn't as clear. * don't disable the BB gating for now, the ar5416 initvals have it, and the ar9160 initval sets it to 0x0. Figure out why before re-enabling this. * migrate the Merlin (ar9280) applicable WAR from the Kite (ar9285) code (which won't get called for Merlin!) and stuff it in here. Modified: head/sys/dev/ath/ath_hal/ar5416/ar5416_reset.c head/sys/dev/ath/ath_hal/ar9002/ar9285_attach.c Modified: head/sys/dev/ath/ath_hal/ar5416/ar5416_reset.c ============================================================================== --- head/sys/dev/ath/ath_hal/ar5416/ar5416_reset.c Thu Mar 3 08:30:28 2011 (r219217) +++ head/sys/dev/ath/ath_hal/ar5416/ar5416_reset.c Thu Mar 3 08:38:31 2011 (r219218) @@ -45,6 +45,7 @@ static void ar5416InitIMR(struct ath_hal static void ar5416InitQoS(struct ath_hal *ah); static void ar5416InitUserSettings(struct ath_hal *ah); static void ar5416UpdateChainMasks(struct ath_hal *ah, HAL_BOOL is_ht); +static void ar5416OverrideIni(struct ath_hal *ah, const struct ieee80211_channel *); #if 0 static HAL_BOOL ar5416ChannelChange(struct ath_hal *, const struct ieee80211_channel *); @@ -183,6 +184,9 @@ ar5416Reset(struct ath_hal *ah, HAL_OPMO AH5416(ah)->ah_writeIni(ah, chan); + /* Override ini values (that can be overriden in this fashion) */ + ar5416OverrideIni(ah, chan); + /* Setup 11n MAC/Phy mode registers */ ar5416Set11nRegs(ah, chan); @@ -2323,3 +2327,57 @@ ar5416GetChannelCenters(struct ath_hal * centers->ext_center = freq; } } + +/* + * Override the INI vals being programmed. + */ +static void +ar5416OverrideIni(struct ath_hal *ah, const struct ieee80211_channel *chan) +{ + uint32_t val; + + /* + * Set the RX_ABORT and RX_DIS and clear if off only after + * RXE is set for MAC. This prevents frames with corrupted + * descriptor status. + */ + OS_REG_SET_BIT(ah, AR_DIAG_SW, (AR_DIAG_RX_DIS | AR_DIAG_RX_ABORT)); + + if (AR_SREV_MERLIN_20_OR_LATER(ah)) { + val = OS_REG_READ(ah, AR_PCU_MISC_MODE2); + + if (!AR_SREV_9271(ah)) + val &= ~AR_PCU_MISC_MODE2_HWWAR1; + + if (AR_SREV_9287_11_OR_LATER(ah)) + val = val & (~AR_PCU_MISC_MODE2_HWWAR2); + + OS_REG_WRITE(ah, AR_PCU_MISC_MODE2, val); + } + + /* + * The AR5416 initvals have this already set to 0x11; AR9160 has + * the register set to 0x0. Figure out whether AR9100/AR9160 needs + * this before moving forward with it. + */ +#if 0 + /* Disable BB clock gating for AR5416v2, AR9100, AR9160 */ + if (AR_SREV_OWL_20_OR_LATER(ah) || AR_SREV_9100(ah) || AR_SREV_SOWL(ah)) { + /* + * Disable BB clock gating + * Necessary to avoid issues on AR5416 2.0 + */ + OS_REG_WRITE(ah, 0x9800 + (651 << 2), 0x11); + } +#endif + + /* + * Disable RIFS search on some chips to avoid baseband + * hang issues. + */ + if (AR_SREV_9100(ah) || AR_SREV_SOWL(ah)) { + val = OS_REG_READ(ah, AR_PHY_HEAVY_CLIP_FACTOR_RIFS); + val &= ~AR_PHY_RIFS_INIT_DELAY; + OS_REG_WRITE(ah, AR_PHY_HEAVY_CLIP_FACTOR_RIFS, val); + } +} Modified: head/sys/dev/ath/ath_hal/ar9002/ar9285_attach.c ============================================================================== --- head/sys/dev/ath/ath_hal/ar9002/ar9285_attach.c Thu Mar 3 08:30:28 2011 (r219217) +++ head/sys/dev/ath/ath_hal/ar9002/ar9285_attach.c Thu Mar 3 08:38:31 2011 (r219218) @@ -339,17 +339,6 @@ ar9285WriteIni(struct ath_hal *ah, const } regWrites = ath_hal_ini_write(ah, &AH5212(ah)->ah_ini_common, 1, regWrites); - - OS_REG_SET_BIT(ah, AR_DIAG_SW, (AR_DIAG_RX_DIS | AR_DIAG_RX_ABORT)); - - if (AR_SREV_MERLIN_10_OR_LATER(ah)) { - uint32_t val; - val = OS_REG_READ(ah, AR_PCU_MISC_MODE2) & - (~AR_PCU_MISC_MODE2_HWWAR1); - OS_REG_WRITE(ah, AR_PCU_MISC_MODE2, val); - OS_REG_WRITE(ah, 0x9800 + (651 << 2), 0x11); - } - } /*