mirror of
https://github.com/FEX-Emu/linux.git
synced 2025-01-08 02:21:18 +00:00
b36b110c57
When a station is associated with an AP and the RF_KILL switch is engaged, numerous error messages were sent to the system log. The error messages were the result of the failure(s) of the various submodules to perform their tasks after the radios were disabled. To resolve this situation, the messages were modified to use a new macro, IWL_DEBUG_QUIET_RFKILL. This macro allows for the RF_KILL error messages to be sent to the log provided that IWL_DEBUG is true and IWL_DL_RADIO is '1'. For all other cases, the error messages resulting from an RFKILL event will not be sent to the system log. Messages logged because of an RFKILL will be tagged with the prefix '(RFKILL)' to clarify the cause of the error. Signed-off-by: Todd Previte <toddX.a.previte@intel.com> Signed-off-by: Wey-Yi Guy <wey-yi.w.guy@intel.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
212 lines
7.8 KiB
C
212 lines
7.8 KiB
C
/******************************************************************************
|
|
*
|
|
* Copyright(c) 2003 - 2011 Intel Corporation. All rights reserved.
|
|
*
|
|
* Portions of this file are derived from the ipw3945 project.
|
|
*
|
|
* 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.
|
|
*
|
|
* Contact Information:
|
|
* Intel Linux Wireless <ilw@linux.intel.com>
|
|
* Intel Corporation, 5200 N.E. Elam Young Parkway, Hillsboro, OR 97124-6497
|
|
*
|
|
*****************************************************************************/
|
|
|
|
#ifndef __iwl_debug_h__
|
|
#define __iwl_debug_h__
|
|
|
|
#include "iwl-bus.h"
|
|
#include "iwl-shared.h"
|
|
|
|
struct iwl_priv;
|
|
|
|
/*No matter what is m (priv, bus, trans), this will work */
|
|
#define IWL_ERR(m, f, a...) dev_err(bus(m)->dev, f, ## a)
|
|
#define IWL_WARN(m, f, a...) dev_warn(bus(m)->dev, f, ## a)
|
|
#define IWL_INFO(m, f, a...) dev_info(bus(m)->dev, f, ## a)
|
|
#define IWL_CRIT(m, f, a...) dev_crit(bus(m)->dev, f, ## a)
|
|
|
|
#define iwl_print_hex_error(m, p, len) \
|
|
do { \
|
|
print_hex_dump(KERN_ERR, "iwl data: ", \
|
|
DUMP_PREFIX_OFFSET, 16, 1, p, len, 1); \
|
|
} while (0)
|
|
|
|
#ifdef CONFIG_IWLWIFI_DEBUG
|
|
#define IWL_DEBUG(m, level, fmt, args...) \
|
|
do { \
|
|
if (iwl_get_debug_level((m)->shrd) & (level)) \
|
|
dev_printk(KERN_ERR, bus(m)->dev, \
|
|
"%c %s " fmt, in_interrupt() ? 'I' : 'U', \
|
|
__func__ , ## args); \
|
|
} while (0)
|
|
|
|
#define IWL_DEBUG_LIMIT(m, level, fmt, args...) \
|
|
do { \
|
|
if (iwl_get_debug_level((m)->shrd) & (level) && net_ratelimit())\
|
|
dev_printk(KERN_ERR, bus(m)->dev, \
|
|
"%c %s " fmt, in_interrupt() ? 'I' : 'U', \
|
|
__func__ , ## args); \
|
|
} while (0)
|
|
|
|
#define iwl_print_hex_dump(m, level, p, len) \
|
|
do { \
|
|
if (iwl_get_debug_level((m)->shrd) & level) \
|
|
print_hex_dump(KERN_DEBUG, "iwl data: ", \
|
|
DUMP_PREFIX_OFFSET, 16, 1, p, len, 1); \
|
|
} while (0)
|
|
|
|
#define IWL_DEBUG_QUIET_RFKILL(p, fmt, args...) \
|
|
do { \
|
|
if (!iwl_is_rfkill(p->shrd)) \
|
|
dev_printk(KERN_ERR, bus(p)->dev, "%c %s " fmt, \
|
|
(in_interrupt() ? 'I' : 'U'), __func__ , ##args); \
|
|
else if (iwl_get_debug_level(p->shrd) & IWL_DL_RADIO) \
|
|
dev_printk(KERN_ERR, bus(p)->dev, "(RFKILL) %c %s " fmt, \
|
|
(in_interrupt() ? 'I' : 'U'), __func__ , ##args); \
|
|
} while (0)
|
|
|
|
#else
|
|
#define IWL_DEBUG(m, level, fmt, args...)
|
|
#define IWL_DEBUG_LIMIT(m, level, fmt, args...)
|
|
#define iwl_print_hex_dump(m, level, p, len)
|
|
#define IWL_DEBUG_QUIET_RFKILL(p, fmt, args...) \
|
|
do { \
|
|
if (!iwl_is_rfkill(p->shrd)) \
|
|
IWL_ERR(p, fmt, ##args); \
|
|
} while (0)
|
|
#endif /* CONFIG_IWLWIFI_DEBUG */
|
|
|
|
#ifdef CONFIG_IWLWIFI_DEBUGFS
|
|
int iwl_dbgfs_register(struct iwl_priv *priv, const char *name);
|
|
void iwl_dbgfs_unregister(struct iwl_priv *priv);
|
|
#else
|
|
static inline int iwl_dbgfs_register(struct iwl_priv *priv, const char *name)
|
|
{
|
|
return 0;
|
|
}
|
|
static inline void iwl_dbgfs_unregister(struct iwl_priv *priv)
|
|
{
|
|
}
|
|
#endif /* CONFIG_IWLWIFI_DEBUGFS */
|
|
|
|
/*
|
|
* To use the debug system:
|
|
*
|
|
* If you are defining a new debug classification, simply add it to the #define
|
|
* list here in the form of
|
|
*
|
|
* #define IWL_DL_xxxx VALUE
|
|
*
|
|
* where xxxx should be the name of the classification (for example, WEP).
|
|
*
|
|
* You then need to either add a IWL_xxxx_DEBUG() macro definition for your
|
|
* classification, or use IWL_DEBUG(IWL_DL_xxxx, ...) whenever you want
|
|
* to send output to that classification.
|
|
*
|
|
* The active debug levels can be accessed via files
|
|
*
|
|
* /sys/module/iwlwifi/parameters/debug
|
|
* when CONFIG_IWLWIFI_DEBUG=y.
|
|
*
|
|
* /sys/kernel/debug/phy0/iwlwifi/debug/debug_level
|
|
* when CONFIG_IWLWIFI_DEBUGFS=y.
|
|
*
|
|
*/
|
|
|
|
/* 0x0000000F - 0x00000001 */
|
|
#define IWL_DL_INFO (1 << 0)
|
|
#define IWL_DL_MAC80211 (1 << 1)
|
|
#define IWL_DL_HCMD (1 << 2)
|
|
#define IWL_DL_STATE (1 << 3)
|
|
/* 0x000000F0 - 0x00000010 */
|
|
#define IWL_DL_MACDUMP (1 << 4)
|
|
#define IWL_DL_HCMD_DUMP (1 << 5)
|
|
#define IWL_DL_EEPROM (1 << 6)
|
|
#define IWL_DL_RADIO (1 << 7)
|
|
/* 0x00000F00 - 0x00000100 */
|
|
#define IWL_DL_POWER (1 << 8)
|
|
#define IWL_DL_TEMP (1 << 9)
|
|
/* reserved (1 << 10) */
|
|
#define IWL_DL_SCAN (1 << 11)
|
|
/* 0x0000F000 - 0x00001000 */
|
|
#define IWL_DL_ASSOC (1 << 12)
|
|
#define IWL_DL_DROP (1 << 13)
|
|
/* reserved (1 << 14) */
|
|
#define IWL_DL_COEX (1 << 15)
|
|
/* 0x000F0000 - 0x00010000 */
|
|
#define IWL_DL_FW (1 << 16)
|
|
#define IWL_DL_RF_KILL (1 << 17)
|
|
#define IWL_DL_FW_ERRORS (1 << 18)
|
|
#define IWL_DL_LED (1 << 19)
|
|
/* 0x00F00000 - 0x00100000 */
|
|
#define IWL_DL_RATE (1 << 20)
|
|
#define IWL_DL_CALIB (1 << 21)
|
|
#define IWL_DL_WEP (1 << 22)
|
|
#define IWL_DL_TX (1 << 23)
|
|
/* 0x0F000000 - 0x01000000 */
|
|
#define IWL_DL_RX (1 << 24)
|
|
#define IWL_DL_ISR (1 << 25)
|
|
#define IWL_DL_HT (1 << 26)
|
|
/* 0xF0000000 - 0x10000000 */
|
|
#define IWL_DL_11H (1 << 28)
|
|
#define IWL_DL_STATS (1 << 29)
|
|
#define IWL_DL_TX_REPLY (1 << 30)
|
|
#define IWL_DL_QOS (1 << 31)
|
|
|
|
#define IWL_DEBUG_INFO(p, f, a...) IWL_DEBUG(p, IWL_DL_INFO, f, ## a)
|
|
#define IWL_DEBUG_MAC80211(p, f, a...) IWL_DEBUG(p, IWL_DL_MAC80211, f, ## a)
|
|
#define IWL_DEBUG_MACDUMP(p, f, a...) IWL_DEBUG(p, IWL_DL_MACDUMP, f, ## a)
|
|
#define IWL_DEBUG_TEMP(p, f, a...) IWL_DEBUG(p, IWL_DL_TEMP, f, ## a)
|
|
#define IWL_DEBUG_SCAN(p, f, a...) IWL_DEBUG(p, IWL_DL_SCAN, f, ## a)
|
|
#define IWL_DEBUG_RX(p, f, a...) IWL_DEBUG(p, IWL_DL_RX, f, ## a)
|
|
#define IWL_DEBUG_TX(p, f, a...) IWL_DEBUG(p, IWL_DL_TX, f, ## a)
|
|
#define IWL_DEBUG_ISR(p, f, a...) IWL_DEBUG(p, IWL_DL_ISR, f, ## a)
|
|
#define IWL_DEBUG_LED(p, f, a...) IWL_DEBUG(p, IWL_DL_LED, f, ## a)
|
|
#define IWL_DEBUG_WEP(p, f, a...) IWL_DEBUG(p, IWL_DL_WEP, f, ## a)
|
|
#define IWL_DEBUG_HC(p, f, a...) IWL_DEBUG(p, IWL_DL_HCMD, f, ## a)
|
|
#define IWL_DEBUG_HC_DUMP(p, f, a...) IWL_DEBUG(p, IWL_DL_HCMD_DUMP, f, ## a)
|
|
#define IWL_DEBUG_EEPROM(p, f, a...) IWL_DEBUG(p, IWL_DL_EEPROM, f, ## a)
|
|
#define IWL_DEBUG_CALIB(p, f, a...) IWL_DEBUG(p, IWL_DL_CALIB, f, ## a)
|
|
#define IWL_DEBUG_FW(p, f, a...) IWL_DEBUG(p, IWL_DL_FW, f, ## a)
|
|
#define IWL_DEBUG_RF_KILL(p, f, a...) IWL_DEBUG(p, IWL_DL_RF_KILL, f, ## a)
|
|
#define IWL_DEBUG_FW_ERRORS(p, f, a...) IWL_DEBUG(p, IWL_DL_FW_ERRORS, f, ## a)
|
|
#define IWL_DEBUG_DROP(p, f, a...) IWL_DEBUG(p, IWL_DL_DROP, f, ## a)
|
|
#define IWL_DEBUG_DROP_LIMIT(p, f, a...) \
|
|
IWL_DEBUG_LIMIT(p, IWL_DL_DROP, f, ## a)
|
|
#define IWL_DEBUG_COEX(p, f, a...) IWL_DEBUG(p, IWL_DL_COEX, f, ## a)
|
|
#define IWL_DEBUG_RATE(p, f, a...) IWL_DEBUG(p, IWL_DL_RATE, f, ## a)
|
|
#define IWL_DEBUG_RATE_LIMIT(p, f, a...) \
|
|
IWL_DEBUG_LIMIT(p, IWL_DL_RATE, f, ## a)
|
|
#define IWL_DEBUG_ASSOC(p, f, a...) \
|
|
IWL_DEBUG(p, IWL_DL_ASSOC | IWL_DL_INFO, f, ## a)
|
|
#define IWL_DEBUG_ASSOC_LIMIT(p, f, a...) \
|
|
IWL_DEBUG_LIMIT(p, IWL_DL_ASSOC | IWL_DL_INFO, f, ## a)
|
|
#define IWL_DEBUG_HT(p, f, a...) IWL_DEBUG(p, IWL_DL_HT, f, ## a)
|
|
#define IWL_DEBUG_STATS(p, f, a...) IWL_DEBUG(p, IWL_DL_STATS, f, ## a)
|
|
#define IWL_DEBUG_STATS_LIMIT(p, f, a...) \
|
|
IWL_DEBUG_LIMIT(p, IWL_DL_STATS, f, ## a)
|
|
#define IWL_DEBUG_TX_REPLY(p, f, a...) IWL_DEBUG(p, IWL_DL_TX_REPLY, f, ## a)
|
|
#define IWL_DEBUG_TX_REPLY_LIMIT(p, f, a...) \
|
|
IWL_DEBUG_LIMIT(p, IWL_DL_TX_REPLY, f, ## a)
|
|
#define IWL_DEBUG_QOS(p, f, a...) IWL_DEBUG(p, IWL_DL_QOS, f, ## a)
|
|
#define IWL_DEBUG_RADIO(p, f, a...) IWL_DEBUG(p, IWL_DL_RADIO, f, ## a)
|
|
#define IWL_DEBUG_POWER(p, f, a...) IWL_DEBUG(p, IWL_DL_POWER, f, ## a)
|
|
#define IWL_DEBUG_11H(p, f, a...) IWL_DEBUG(p, IWL_DL_11H, f, ## a)
|
|
|
|
#endif
|