bdcd817079
Last May we started working on cleaning up ath6kl driver which is currently in staging. The work has happened in a separate ath6kl-cleanup tree: http://git.kernel.org/?p=linux/kernel/git/kvalo/ath6kl-cleanup.git;a=summary After over 1100 (!) patches we have now reached a state where I would like to start discussing about pushing the driver to the wireless trees and replacing the staging driver. The driver is now a lot smaller and looks like a proper Linux driver. The size of the driver (measured with simple wc -l) dropped from 49 kLOC to 18 kLOC and the number of the .c and .h files dropped from 107 to 22. Most importantly the number of subdirectories reduced from 26 to zero :) There are two remaining checkpatch warnings in the driver which we decided to omit for now: drivers/net/wireless/ath/ath6kl/debug.c:31: WARNING: printk() should include KERN_ facility level drivers/net/wireless/ath/ath6kl/sdio.c:527: WARNING: msleep < 20ms can sleep for up to 20ms; see Documentation/timers/timers-howto.txt The driver has endian annotations for all the hardware specific structures and there are no sparse errors. Unfortunately I don't have any big endian hardware to test that right now. We have been testing the driver both on x86 and arm platforms. The code is also compiled with sparc and parisc cross compilers. Notable missing features compared to the current staging driver are: o HCI over SDIO support o nl80211 testmode o firmware logging o suspend support Testmode, firmware logging and suspend support will be added soon. HCI over SDIO support will be more difficult as the HCI driver needs to share code with the wifi driver. This is something we need to research more. Also I want to point out the changes I did for signed endian support. As I wasn't able to find any support for signed endian annotations I decided to follow what NTFS has done and added my own. Grep for sle16 and sle32, especially from wmi.h. Various people have been working on the cleanup, the hall of fame based on number of patches is: 543 Vasanthakumar Thiagarajan 403 Raja Mani 252 Kalle Valo 16 Vivek Natarajan 12 Suraj Sumangala 3 Joe Perches 2 Jouni Malinen Signed-off-by: Vasanthakumar Thiagarajan <vthiagar@qca.qualcomm.com> Signed-off-by: Raja Mani <rmani@qca.qualcomm.com> Signed-off-by: Vivek Natarajan <nataraja@qca.qualcomm.com> Signed-off-by: Suraj Sumangala <surajs@qca.qualcomm.com> Signed-off-by: Joe Perches <joe@perches.com> Signed-off-by: Jouni Malinen <jouni@qca.qualcomm.com> Signed-off-by: Kalle Valo <kvalo@qca.qualcomm.com>
151 lines
4.6 KiB
C
151 lines
4.6 KiB
C
/*
|
|
* Copyright (c) 2004-2011 Atheros Communications Inc.
|
|
*
|
|
* Permission to use, copy, modify, and/or distribute this software for any
|
|
* purpose with or without fee is hereby granted, provided that the above
|
|
* copyright notice and this permission notice appear in all copies.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
*/
|
|
|
|
#include "core.h"
|
|
#include "debug.h"
|
|
|
|
int ath6kl_printk(const char *level, const char *fmt, ...)
|
|
{
|
|
struct va_format vaf;
|
|
va_list args;
|
|
int rtn;
|
|
|
|
va_start(args, fmt);
|
|
|
|
vaf.fmt = fmt;
|
|
vaf.va = &args;
|
|
|
|
rtn = printk("%sath6kl: %pV", level, &vaf);
|
|
|
|
va_end(args);
|
|
|
|
return rtn;
|
|
}
|
|
|
|
#ifdef CONFIG_ATH6KL_DEBUG
|
|
void ath6kl_dump_registers(struct ath6kl_device *dev,
|
|
struct ath6kl_irq_proc_registers *irq_proc_reg,
|
|
struct ath6kl_irq_enable_reg *irq_enable_reg)
|
|
{
|
|
|
|
ath6kl_dbg(ATH6KL_DBG_ANY, ("<------- Register Table -------->\n"));
|
|
|
|
if (irq_proc_reg != NULL) {
|
|
ath6kl_dbg(ATH6KL_DBG_ANY,
|
|
"Host Int status: 0x%x\n",
|
|
irq_proc_reg->host_int_status);
|
|
ath6kl_dbg(ATH6KL_DBG_ANY,
|
|
"CPU Int status: 0x%x\n",
|
|
irq_proc_reg->cpu_int_status);
|
|
ath6kl_dbg(ATH6KL_DBG_ANY,
|
|
"Error Int status: 0x%x\n",
|
|
irq_proc_reg->error_int_status);
|
|
ath6kl_dbg(ATH6KL_DBG_ANY,
|
|
"Counter Int status: 0x%x\n",
|
|
irq_proc_reg->counter_int_status);
|
|
ath6kl_dbg(ATH6KL_DBG_ANY,
|
|
"Mbox Frame: 0x%x\n",
|
|
irq_proc_reg->mbox_frame);
|
|
ath6kl_dbg(ATH6KL_DBG_ANY,
|
|
"Rx Lookahead Valid: 0x%x\n",
|
|
irq_proc_reg->rx_lkahd_valid);
|
|
ath6kl_dbg(ATH6KL_DBG_ANY,
|
|
"Rx Lookahead 0: 0x%x\n",
|
|
irq_proc_reg->rx_lkahd[0]);
|
|
ath6kl_dbg(ATH6KL_DBG_ANY,
|
|
"Rx Lookahead 1: 0x%x\n",
|
|
irq_proc_reg->rx_lkahd[1]);
|
|
|
|
if (dev->ar->mbox_info.gmbox_addr != 0) {
|
|
/*
|
|
* If the target supports GMBOX hardware, dump some
|
|
* additional state.
|
|
*/
|
|
ath6kl_dbg(ATH6KL_DBG_ANY,
|
|
"GMBOX Host Int status 2: 0x%x\n",
|
|
irq_proc_reg->host_int_status2);
|
|
ath6kl_dbg(ATH6KL_DBG_ANY,
|
|
"GMBOX RX Avail: 0x%x\n",
|
|
irq_proc_reg->gmbox_rx_avail);
|
|
ath6kl_dbg(ATH6KL_DBG_ANY,
|
|
"GMBOX lookahead alias 0: 0x%x\n",
|
|
irq_proc_reg->rx_gmbox_lkahd_alias[0]);
|
|
ath6kl_dbg(ATH6KL_DBG_ANY,
|
|
"GMBOX lookahead alias 1: 0x%x\n",
|
|
irq_proc_reg->rx_gmbox_lkahd_alias[1]);
|
|
}
|
|
|
|
}
|
|
|
|
if (irq_enable_reg != NULL) {
|
|
ath6kl_dbg(ATH6KL_DBG_ANY,
|
|
"Int status Enable: 0x%x\n",
|
|
irq_enable_reg->int_status_en);
|
|
ath6kl_dbg(ATH6KL_DBG_ANY, "Counter Int status Enable: 0x%x\n",
|
|
irq_enable_reg->cntr_int_status_en);
|
|
}
|
|
ath6kl_dbg(ATH6KL_DBG_ANY, "<------------------------------->\n");
|
|
}
|
|
|
|
static void dump_cred_dist(struct htc_endpoint_credit_dist *ep_dist)
|
|
{
|
|
ath6kl_dbg(ATH6KL_DBG_ANY,
|
|
"--- endpoint: %d svc_id: 0x%X ---\n",
|
|
ep_dist->endpoint, ep_dist->svc_id);
|
|
ath6kl_dbg(ATH6KL_DBG_ANY, " dist_flags : 0x%X\n",
|
|
ep_dist->dist_flags);
|
|
ath6kl_dbg(ATH6KL_DBG_ANY, " cred_norm : %d\n",
|
|
ep_dist->cred_norm);
|
|
ath6kl_dbg(ATH6KL_DBG_ANY, " cred_min : %d\n",
|
|
ep_dist->cred_min);
|
|
ath6kl_dbg(ATH6KL_DBG_ANY, " credits : %d\n",
|
|
ep_dist->credits);
|
|
ath6kl_dbg(ATH6KL_DBG_ANY, " cred_assngd : %d\n",
|
|
ep_dist->cred_assngd);
|
|
ath6kl_dbg(ATH6KL_DBG_ANY, " seek_cred : %d\n",
|
|
ep_dist->seek_cred);
|
|
ath6kl_dbg(ATH6KL_DBG_ANY, " cred_sz : %d\n",
|
|
ep_dist->cred_sz);
|
|
ath6kl_dbg(ATH6KL_DBG_ANY, " cred_per_msg : %d\n",
|
|
ep_dist->cred_per_msg);
|
|
ath6kl_dbg(ATH6KL_DBG_ANY, " cred_to_dist : %d\n",
|
|
ep_dist->cred_to_dist);
|
|
ath6kl_dbg(ATH6KL_DBG_ANY, " txq_depth : %d\n",
|
|
get_queue_depth(&((struct htc_endpoint *)
|
|
ep_dist->htc_rsvd)->txq));
|
|
ath6kl_dbg(ATH6KL_DBG_ANY,
|
|
"----------------------------------\n");
|
|
}
|
|
|
|
void dump_cred_dist_stats(struct htc_target *target)
|
|
{
|
|
struct htc_endpoint_credit_dist *ep_list;
|
|
|
|
if (!AR_DBG_LVL_CHECK(ATH6KL_DBG_TRC))
|
|
return;
|
|
|
|
list_for_each_entry(ep_list, &target->cred_dist_list, list)
|
|
dump_cred_dist(ep_list);
|
|
|
|
ath6kl_dbg(ATH6KL_DBG_HTC_SEND, "ctxt:%p dist:%p\n",
|
|
target->cred_dist_cntxt, NULL);
|
|
ath6kl_dbg(ATH6KL_DBG_TRC, "credit distribution, total : %d, free : %d\n",
|
|
target->cred_dist_cntxt->total_avail_credits,
|
|
target->cred_dist_cntxt->cur_free_credits);
|
|
}
|
|
|
|
#endif
|