|
@@ -71,7 +71,21 @@ static void iwl6000_set_ct_threshold(struct iwl_priv *priv)
|
|
|
/* NIC configuration for 6000 series */
|
|
|
static void iwl6000_nic_config(struct iwl_priv *priv)
|
|
|
{
|
|
|
- iwl5000_nic_config(priv);
|
|
|
+ u16 radio_cfg;
|
|
|
+
|
|
|
+ radio_cfg = iwl_eeprom_query16(priv, EEPROM_RADIO_CONFIG);
|
|
|
+
|
|
|
+ /* write radio config values to register */
|
|
|
+ if (EEPROM_RF_CFG_TYPE_MSK(radio_cfg) <= EEPROM_RF_CONFIG_TYPE_MAX)
|
|
|
+ iwl_set_bit(priv, CSR_HW_IF_CONFIG_REG,
|
|
|
+ EEPROM_RF_CFG_TYPE_MSK(radio_cfg) |
|
|
|
+ EEPROM_RF_CFG_STEP_MSK(radio_cfg) |
|
|
|
+ EEPROM_RF_CFG_DASH_MSK(radio_cfg));
|
|
|
+
|
|
|
+ /* set CSR_HW_CONFIG_REG for uCode use */
|
|
|
+ iwl_set_bit(priv, CSR_HW_IF_CONFIG_REG,
|
|
|
+ CSR_HW_IF_CONFIG_REG_BIT_RADIO_SI |
|
|
|
+ CSR_HW_IF_CONFIG_REG_BIT_MAC_SI);
|
|
|
|
|
|
/* no locking required for register write */
|
|
|
if (priv->cfg->pa_type == IWL_PA_HYBRID) {
|