2013-05-12 18:43:35 +07:00
|
|
|
/*
|
2016-05-17 02:23:35 +07:00
|
|
|
* Copyright (c) 2013,2016 Qualcomm Atheros, Inc.
|
2018-02-27 01:12:13 +07:00
|
|
|
* Copyright (c) 2018, The Linux Foundation. All rights reserved.
|
2013-05-12 18:43:35 +07:00
|
|
|
*
|
|
|
|
* 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 "wil6210.h"
|
|
|
|
#include "trace.h"
|
|
|
|
|
2016-04-26 18:41:38 +07:00
|
|
|
void __wil_err(struct wil6210_priv *wil, const char *fmt, ...)
|
2013-05-12 18:43:35 +07:00
|
|
|
{
|
2016-05-17 02:23:35 +07:00
|
|
|
struct va_format vaf;
|
2013-05-12 18:43:35 +07:00
|
|
|
va_list args;
|
|
|
|
|
|
|
|
va_start(args, fmt);
|
2016-05-17 02:23:35 +07:00
|
|
|
vaf.fmt = fmt;
|
2013-05-12 18:43:35 +07:00
|
|
|
vaf.va = &args;
|
2018-02-27 01:12:13 +07:00
|
|
|
netdev_err(wil->main_ndev, "%pV", &vaf);
|
2013-05-12 18:43:35 +07:00
|
|
|
trace_wil6210_log_err(&vaf);
|
|
|
|
va_end(args);
|
|
|
|
}
|
|
|
|
|
2016-04-26 18:41:38 +07:00
|
|
|
void __wil_err_ratelimited(struct wil6210_priv *wil, const char *fmt, ...)
|
2014-12-01 20:33:16 +07:00
|
|
|
{
|
2016-05-17 02:23:35 +07:00
|
|
|
struct va_format vaf;
|
|
|
|
va_list args;
|
2014-12-01 20:33:16 +07:00
|
|
|
|
2016-05-17 02:23:35 +07:00
|
|
|
if (!net_ratelimit())
|
|
|
|
return;
|
|
|
|
|
|
|
|
va_start(args, fmt);
|
|
|
|
vaf.fmt = fmt;
|
|
|
|
vaf.va = &args;
|
2018-02-27 01:12:13 +07:00
|
|
|
netdev_err(wil->main_ndev, "%pV", &vaf);
|
2016-05-17 02:23:35 +07:00
|
|
|
trace_wil6210_log_err(&vaf);
|
|
|
|
va_end(args);
|
2014-12-01 20:33:16 +07:00
|
|
|
}
|
|
|
|
|
2016-04-26 18:41:39 +07:00
|
|
|
void wil_dbg_ratelimited(const struct wil6210_priv *wil, const char *fmt, ...)
|
|
|
|
{
|
|
|
|
struct va_format vaf;
|
|
|
|
va_list args;
|
|
|
|
|
|
|
|
if (!net_ratelimit())
|
|
|
|
return;
|
|
|
|
|
|
|
|
va_start(args, fmt);
|
|
|
|
vaf.fmt = fmt;
|
|
|
|
vaf.va = &args;
|
2018-02-27 01:12:13 +07:00
|
|
|
netdev_dbg(wil->main_ndev, "%pV", &vaf);
|
2016-04-26 18:41:39 +07:00
|
|
|
trace_wil6210_log_dbg(&vaf);
|
|
|
|
va_end(args);
|
|
|
|
}
|
|
|
|
|
2016-04-26 18:41:38 +07:00
|
|
|
void __wil_info(struct wil6210_priv *wil, const char *fmt, ...)
|
2013-05-12 18:43:35 +07:00
|
|
|
{
|
2016-05-17 02:23:35 +07:00
|
|
|
struct va_format vaf;
|
2013-05-12 18:43:35 +07:00
|
|
|
va_list args;
|
|
|
|
|
|
|
|
va_start(args, fmt);
|
2016-05-17 02:23:35 +07:00
|
|
|
vaf.fmt = fmt;
|
2013-05-12 18:43:35 +07:00
|
|
|
vaf.va = &args;
|
2018-02-27 01:12:13 +07:00
|
|
|
netdev_info(wil->main_ndev, "%pV", &vaf);
|
2013-05-12 18:43:35 +07:00
|
|
|
trace_wil6210_log_info(&vaf);
|
|
|
|
va_end(args);
|
|
|
|
}
|
|
|
|
|
Merge tag 'master-2014-09-16' of git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-next
John W. Linville says:
====================
pull request: wireless-next 2014-09-22
Please pull this batch of updates intended for the 3.18 stream...
For the mac80211 bits, Johannes says:
"This time, I have some rate minstrel improvements, support for a very
small feature from CCX that Steinar reverse-engineered, dynamic ACK
timeout support, a number of changes for TDLS, early support for radio
resource measurement and many fixes. Also, I'm changing a number of
places to clear key memory when it's freed and Intel claims copyright
for code they developed."
For the bluetooth bits, Johan says:
"Here are some more patches intended for 3.18. Most of them are cleanups
or fixes for SMP. The only exception is a fix for BR/EDR L2CAP fixed
channels which should now work better together with the L2CAP
information request procedure."
For the iwlwifi bits, Emmanuel says:
"I fix here dvm which was broken by my last pull request. Arik
continues to work on TDLS and Luca solved a few issues in CT-Kill. Eyal
keeps digging into rate scaling code, more to come soon. Besides this,
nothing really special here."
Beyond that, there are the usual big batches of updates to ath9k, b43,
mwifiex, and wil6210 as well as a handful of other bits here and there.
Also, rtlwifi gets some btcoexist attention from Larry.
Please let me know if there are problems!
====================
Had to adjust the wil6210 code to comply with Joe Perches's recent
change in net-next to make the netdev_*() routines return void instead
of 'int'.
Signed-off-by: David S. Miller <davem@davemloft.net>
2014-09-27 02:19:05 +07:00
|
|
|
void wil_dbg_trace(struct wil6210_priv *wil, const char *fmt, ...)
|
2013-05-12 18:43:35 +07:00
|
|
|
{
|
2016-05-17 02:23:35 +07:00
|
|
|
struct va_format vaf;
|
2013-05-12 18:43:35 +07:00
|
|
|
va_list args;
|
|
|
|
|
|
|
|
va_start(args, fmt);
|
2016-05-17 02:23:35 +07:00
|
|
|
vaf.fmt = fmt;
|
2013-05-12 18:43:35 +07:00
|
|
|
vaf.va = &args;
|
|
|
|
trace_wil6210_log_dbg(&vaf);
|
|
|
|
va_end(args);
|
|
|
|
}
|