2011-08-26 13:10:36 +07:00
|
|
|
/******************************************************************************
|
|
|
|
*
|
|
|
|
* This file is provided under a dual BSD/GPLv2 license. When using or
|
|
|
|
* redistributing this file, you may do so under either license.
|
|
|
|
*
|
|
|
|
* GPL LICENSE SUMMARY
|
|
|
|
*
|
2011-12-28 02:21:32 +07:00
|
|
|
* Copyright(c) 2007 - 2012 Intel Corporation. All rights reserved.
|
2011-08-26 13:10:36 +07:00
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of version 2 of the GNU General Public License as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful, but
|
|
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110,
|
|
|
|
* USA
|
|
|
|
*
|
|
|
|
* The full GNU General Public License is included in this distribution
|
|
|
|
* in the file called LICENSE.GPL.
|
|
|
|
*
|
|
|
|
* Contact Information:
|
|
|
|
* Intel Linux Wireless <ilw@linux.intel.com>
|
|
|
|
* Intel Corporation, 5200 N.E. Elam Young Parkway, Hillsboro, OR 97124-6497
|
|
|
|
*
|
|
|
|
* BSD LICENSE
|
|
|
|
*
|
2011-12-28 02:21:32 +07:00
|
|
|
* Copyright(c) 2005 - 2012 Intel Corporation. All rights reserved.
|
2011-08-26 13:10:36 +07:00
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
*
|
|
|
|
* * Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* * Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in
|
|
|
|
* the documentation and/or other materials provided with the
|
|
|
|
* distribution.
|
|
|
|
* * Neither the name Intel Corporation nor the names of its
|
|
|
|
* contributors may be used to endorse or promote products derived
|
|
|
|
* from this software without specific prior written permission.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
|
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
|
|
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
|
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
|
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
|
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*
|
|
|
|
*****************************************************************************/
|
|
|
|
#ifndef __iwl_shared_h__
|
|
|
|
#define __iwl_shared_h__
|
|
|
|
|
2011-08-26 13:11:13 +07:00
|
|
|
#include <linux/types.h>
|
|
|
|
#include <linux/spinlock.h>
|
|
|
|
#include <linux/gfp.h>
|
2011-08-26 13:11:22 +07:00
|
|
|
#include <net/mac80211.h>
|
2011-08-26 13:11:13 +07:00
|
|
|
|
2011-08-26 13:11:18 +07:00
|
|
|
#include "iwl-commands.h"
|
2012-03-07 04:30:37 +07:00
|
|
|
#include "iwl-fw.h"
|
2012-04-10 07:46:59 +07:00
|
|
|
#include "iwl-config.h"
|
2011-08-26 13:11:18 +07:00
|
|
|
|
2011-09-16 01:46:34 +07:00
|
|
|
/**
|
|
|
|
* DOC: shared area - role and goal
|
|
|
|
*
|
|
|
|
* The shared area contains all the data exported by the upper layer to the
|
|
|
|
* other layers. Since the bus and transport layer shouldn't dereference
|
|
|
|
* iwl_priv, all the data needed by the upper layer and the transport / bus
|
|
|
|
* layer must be here.
|
|
|
|
* The shared area also holds pointer to all the other layers. This allows a
|
|
|
|
* layer to call a function from another layer.
|
|
|
|
*
|
|
|
|
* NOTE: All the layers hold a pointer to the shared area which must be shrd.
|
|
|
|
* A few macros assume that (_m)->shrd points to the shared area no matter
|
|
|
|
* what _m is.
|
|
|
|
*
|
|
|
|
* gets notifications about enumeration, suspend, resume.
|
|
|
|
* For the moment, the bus layer is not a linux kernel module as itself, and
|
|
|
|
* the module_init function of the driver must call the bus specific
|
|
|
|
* registration functions. These functions are listed at the end of this file.
|
|
|
|
* For the moment, there is only one implementation of this interface: PCI-e.
|
|
|
|
* This implementation is iwl-pci.c
|
|
|
|
*/
|
iwlagn: bus layer chooses its transport layer
Remove iwl_transport_register which was a W/A. The bus layer knows what
transport to use. So now, the bus layer gives the upper layer a pointer to the
iwl_trans_ops struct that it wants to use. The upper layer then, allocates the
desired transport layer using iwl_trans_ops->alloc function.
As a result of this, priv->trans, no longer exists, priv holds a pointer to
iwl_shared, which holds a pointer to iwl_trans. This required to change all the
calls to the transport layer from upper layer. While we were at it, trans_X
inlines have been renamed to iwl_trans_X to avoid confusions, which of course
required to rename the functions inside the transport layer because of
conflicts in names. So the static API functions inside the transport layer
implementation have been renamed to iwl_trans_pcie_X.
Until now, the IRQ / Tasklet were initialized in iwl_transport_layer. This is
confusing since the registration doesn't mean to request IRQ, so I added a
handler for that.
Signed-off-by: Emmanuel Grumbach <emmanuel.grumbach@intel.com>
Signed-off-by: Wey-Yi Guy <wey-yi.w.guy@intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
2011-08-26 13:10:48 +07:00
|
|
|
|
2011-08-26 13:10:36 +07:00
|
|
|
struct iwl_priv;
|
2011-12-01 07:12:59 +07:00
|
|
|
struct iwl_trans;
|
iwlagn: bus layer chooses its transport layer
Remove iwl_transport_register which was a W/A. The bus layer knows what
transport to use. So now, the bus layer gives the upper layer a pointer to the
iwl_trans_ops struct that it wants to use. The upper layer then, allocates the
desired transport layer using iwl_trans_ops->alloc function.
As a result of this, priv->trans, no longer exists, priv holds a pointer to
iwl_shared, which holds a pointer to iwl_trans. This required to change all the
calls to the transport layer from upper layer. While we were at it, trans_X
inlines have been renamed to iwl_trans_X to avoid confusions, which of course
required to rename the functions inside the transport layer because of
conflicts in names. So the static API functions inside the transport layer
implementation have been renamed to iwl_trans_pcie_X.
Until now, the IRQ / Tasklet were initialized in iwl_transport_layer. This is
confusing since the registration doesn't mean to request IRQ, so I added a
handler for that.
Signed-off-by: Emmanuel Grumbach <emmanuel.grumbach@intel.com>
Signed-off-by: Wey-Yi Guy <wey-yi.w.guy@intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
2011-08-26 13:10:48 +07:00
|
|
|
struct iwl_trans_ops;
|
2011-08-26 13:10:36 +07:00
|
|
|
|
2011-10-01 01:40:20 +07:00
|
|
|
#define DRV_NAME "iwlwifi"
|
2011-08-26 13:11:16 +07:00
|
|
|
#define IWLWIFI_VERSION "in-tree:"
|
2011-12-28 02:21:32 +07:00
|
|
|
#define DRV_COPYRIGHT "Copyright(c) 2003-2012 Intel Corporation"
|
2011-08-26 13:11:16 +07:00
|
|
|
#define DRV_AUTHOR "<ilw@linux.intel.com>"
|
|
|
|
|
2011-08-26 13:10:36 +07:00
|
|
|
extern struct iwl_mod_params iwlagn_mod_params;
|
|
|
|
|
2011-12-13 15:07:40 +07:00
|
|
|
#define IWL_DISABLE_HT_ALL BIT(0)
|
|
|
|
#define IWL_DISABLE_HT_TXAGG BIT(1)
|
|
|
|
#define IWL_DISABLE_HT_RXAGG BIT(2)
|
|
|
|
|
2011-08-26 13:10:58 +07:00
|
|
|
/**
|
|
|
|
* struct iwl_mod_params
|
2011-09-16 01:46:34 +07:00
|
|
|
*
|
|
|
|
* Holds the module parameters
|
|
|
|
*
|
2011-08-26 13:10:58 +07:00
|
|
|
* @sw_crypto: using hardware encryption, default = 0
|
2011-12-13 15:07:40 +07:00
|
|
|
* @disable_11n: disable 11n capabilities, default = 0,
|
|
|
|
* use IWL_DISABLE_HT_* constants
|
2011-08-26 13:10:58 +07:00
|
|
|
* @amsdu_size_8K: enable 8K amsdu size, default = 1
|
|
|
|
* @restart_fw: restart firmware, default = 1
|
|
|
|
* @plcp_check: enable plcp health check, default = true
|
2011-12-02 23:19:19 +07:00
|
|
|
* @wd_disable: enable stuck queue check, default = 0
|
2011-08-26 13:10:58 +07:00
|
|
|
* @bt_coex_active: enable bt coex, default = true
|
|
|
|
* @led_mode: system default, default = 0
|
|
|
|
* @power_save: disable power save, default = false
|
|
|
|
* @power_level: power level, default = 1
|
|
|
|
* @debug_level: levels are IWL_DL_*
|
|
|
|
* @ant_coupling: antenna coupling in dB, default = 0
|
|
|
|
* @bt_ch_announce: BT channel inhibition, default = enable
|
|
|
|
* @auto_agg: enable agg. without check, default = true
|
|
|
|
*/
|
2011-08-26 13:10:36 +07:00
|
|
|
struct iwl_mod_params {
|
2011-08-26 13:10:58 +07:00
|
|
|
int sw_crypto;
|
2011-12-13 15:07:40 +07:00
|
|
|
unsigned int disable_11n;
|
2011-08-26 13:10:58 +07:00
|
|
|
int amsdu_size_8K;
|
|
|
|
int restart_fw;
|
|
|
|
bool plcp_check;
|
2011-12-02 23:19:19 +07:00
|
|
|
int wd_disable;
|
2011-08-26 13:10:58 +07:00
|
|
|
bool bt_coex_active;
|
|
|
|
int led_mode;
|
|
|
|
bool power_save;
|
|
|
|
int power_level;
|
|
|
|
u32 debug_level;
|
2011-08-26 13:10:36 +07:00
|
|
|
int ant_coupling;
|
2011-08-26 13:10:58 +07:00
|
|
|
bool bt_ch_announce;
|
|
|
|
bool auto_agg;
|
2011-08-26 13:10:36 +07:00
|
|
|
};
|
|
|
|
|
2011-08-26 13:10:37 +07:00
|
|
|
/**
|
|
|
|
* struct iwl_shared - shared fields for all the layers of the driver
|
|
|
|
*
|
2011-12-07 19:46:24 +07:00
|
|
|
* @wowlan: are we running wowlan uCode
|
2011-08-26 13:10:37 +07:00
|
|
|
* @bus: pointer to the bus layer data
|
2011-12-16 22:07:36 +07:00
|
|
|
* @cfg: see struct iwl_cfg
|
2011-08-26 13:10:37 +07:00
|
|
|
* @priv: pointer to the upper layer data
|
2011-12-07 19:46:24 +07:00
|
|
|
* @trans: pointer to the transport layer data
|
2012-02-08 05:45:58 +07:00
|
|
|
* @nic: pointer to the nic data
|
2011-08-26 13:10:43 +07:00
|
|
|
* @lock: protect general shared data
|
2011-12-16 22:07:36 +07:00
|
|
|
* @eeprom: pointer to the eeprom/OTP image
|
2011-08-26 13:10:37 +07:00
|
|
|
*/
|
|
|
|
struct iwl_shared {
|
2012-03-06 02:24:33 +07:00
|
|
|
const struct iwl_cfg *cfg;
|
iwlagn: bus layer chooses its transport layer
Remove iwl_transport_register which was a W/A. The bus layer knows what
transport to use. So now, the bus layer gives the upper layer a pointer to the
iwl_trans_ops struct that it wants to use. The upper layer then, allocates the
desired transport layer using iwl_trans_ops->alloc function.
As a result of this, priv->trans, no longer exists, priv holds a pointer to
iwl_shared, which holds a pointer to iwl_trans. This required to change all the
calls to the transport layer from upper layer. While we were at it, trans_X
inlines have been renamed to iwl_trans_X to avoid confusions, which of course
required to rename the functions inside the transport layer because of
conflicts in names. So the static API functions inside the transport layer
implementation have been renamed to iwl_trans_pcie_X.
Until now, the IRQ / Tasklet were initialized in iwl_transport_layer. This is
confusing since the registration doesn't mean to request IRQ, so I added a
handler for that.
Signed-off-by: Emmanuel Grumbach <emmanuel.grumbach@intel.com>
Signed-off-by: Wey-Yi Guy <wey-yi.w.guy@intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
2011-08-26 13:10:48 +07:00
|
|
|
struct iwl_trans *trans;
|
2012-03-07 04:30:38 +07:00
|
|
|
void *drv;
|
2011-08-26 13:10:37 +07:00
|
|
|
};
|
|
|
|
|
2012-02-28 04:53:32 +07:00
|
|
|
/*Whatever _m is (iwl_trans, iwl_priv, these macros will work */
|
2011-12-16 22:07:36 +07:00
|
|
|
#define cfg(_m) ((_m)->shrd->cfg)
|
iwlagn: bus layer chooses its transport layer
Remove iwl_transport_register which was a W/A. The bus layer knows what
transport to use. So now, the bus layer gives the upper layer a pointer to the
iwl_trans_ops struct that it wants to use. The upper layer then, allocates the
desired transport layer using iwl_trans_ops->alloc function.
As a result of this, priv->trans, no longer exists, priv holds a pointer to
iwl_shared, which holds a pointer to iwl_trans. This required to change all the
calls to the transport layer from upper layer. While we were at it, trans_X
inlines have been renamed to iwl_trans_X to avoid confusions, which of course
required to rename the functions inside the transport layer because of
conflicts in names. So the static API functions inside the transport layer
implementation have been renamed to iwl_trans_pcie_X.
Until now, the IRQ / Tasklet were initialized in iwl_transport_layer. This is
confusing since the registration doesn't mean to request IRQ, so I added a
handler for that.
Signed-off-by: Emmanuel Grumbach <emmanuel.grumbach@intel.com>
Signed-off-by: Wey-Yi Guy <wey-yi.w.guy@intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
2011-08-26 13:10:48 +07:00
|
|
|
#define trans(_m) ((_m)->shrd->trans)
|
2011-08-26 13:10:37 +07:00
|
|
|
|
2012-03-06 02:24:30 +07:00
|
|
|
static inline bool iwl_have_debug_level(u32 level)
|
2011-08-26 13:10:38 +07:00
|
|
|
{
|
2012-03-06 02:24:30 +07:00
|
|
|
return iwlagn_mod_params.debug_level & level;
|
2011-08-26 13:10:38 +07:00
|
|
|
}
|
|
|
|
|
2011-08-26 13:11:22 +07:00
|
|
|
enum iwl_rxon_context_id {
|
|
|
|
IWL_RXON_CTX_BSS,
|
|
|
|
IWL_RXON_CTX_PAN,
|
|
|
|
|
|
|
|
NUM_IWL_RXON_CTX
|
|
|
|
};
|
|
|
|
|
2011-09-06 23:31:19 +07:00
|
|
|
const char *get_cmd_string(u8 cmd);
|
2011-09-16 01:46:31 +07:00
|
|
|
|
2011-09-06 23:31:19 +07:00
|
|
|
#define IWL_CMD(x) case x: return #x
|
2011-08-26 13:11:25 +07:00
|
|
|
|
2011-08-26 13:11:04 +07:00
|
|
|
/*****************************************************
|
|
|
|
* DRIVER STATUS FUNCTIONS
|
|
|
|
******************************************************/
|
|
|
|
#define STATUS_HCMD_ACTIVE 0 /* host command in progress */
|
|
|
|
/* 1 is unused (used to be STATUS_HCMD_SYNC_ACTIVE) */
|
|
|
|
#define STATUS_INT_ENABLED 2
|
|
|
|
#define STATUS_RF_KILL_HW 3
|
|
|
|
#define STATUS_CT_KILL 4
|
|
|
|
#define STATUS_INIT 5
|
|
|
|
#define STATUS_ALIVE 6
|
|
|
|
#define STATUS_READY 7
|
|
|
|
#define STATUS_TEMPERATURE 8
|
|
|
|
#define STATUS_GEO_CONFIGURED 9
|
|
|
|
#define STATUS_EXIT_PENDING 10
|
|
|
|
#define STATUS_STATISTICS 12
|
|
|
|
#define STATUS_SCANNING 13
|
|
|
|
#define STATUS_SCAN_ABORTING 14
|
|
|
|
#define STATUS_SCAN_HW 15
|
|
|
|
#define STATUS_POWER_PMI 16
|
|
|
|
#define STATUS_FW_ERROR 17
|
|
|
|
#define STATUS_DEVICE_ENABLED 18
|
|
|
|
#define STATUS_CHANNEL_SWITCH_PENDING 19
|
2011-09-23 05:15:00 +07:00
|
|
|
#define STATUS_SCAN_COMPLETE 20
|
2011-08-26 13:11:04 +07:00
|
|
|
|
2011-08-26 13:10:36 +07:00
|
|
|
#endif /* #__iwl_shared_h__ */
|