2009-04-14 22:11:20 +02:00
/*
* Copyright ( c ) 2009 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 .
*/
2012-03-18 17:30:52 -07:00
# define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
2009-04-14 22:11:20 +02:00
# include <linux/kernel.h>
# include <linux/module.h>
2009-08-12 09:56:59 -07:00
# include "ath.h"
2014-09-27 13:27:45 +05:30
# include "trace.h"
2009-08-12 09:56:59 -07:00
2009-04-14 22:11:20 +02:00
MODULE_AUTHOR ( " Atheros Communications " ) ;
MODULE_DESCRIPTION ( " Shared library for Atheros wireless LAN cards. " ) ;
MODULE_LICENSE ( " Dual BSD/GPL " ) ;
2009-08-12 09:56:59 -07:00
struct sk_buff * ath_rxbuf_alloc ( struct ath_common * common ,
u32 len ,
gfp_t gfp_mask )
{
struct sk_buff * skb ;
u32 off ;
/*
* Cache - line - align . This is important ( for the
* 5210 at least ) as not doing so causes bogus data
* in rx ' d frames .
*/
/* Note: the kernel can allocate a value greater than
* what we ask it to give us . We really only need 4 KB as that
* is this hardware supports and in fact we need at least 3849
* as that is the MAX AMSDU size this hardware supports .
* Unfortunately this means we may get 8 KB here from the
* kernel . . . and that is actually what is observed on some
* systems : ( */
skb = __dev_alloc_skb ( len + common - > cachelsz - 1 , gfp_mask ) ;
if ( skb ! = NULL ) {
off = ( ( unsigned long ) skb - > data ) % common - > cachelsz ;
if ( off ! = 0 )
skb_reserve ( skb , common - > cachelsz - off ) ;
} else {
2012-03-18 17:30:52 -07:00
pr_err ( " skbuff alloc of size %u failed \n " , len ) ;
2009-08-12 09:56:59 -07:00
return NULL ;
}
return skb ;
}
EXPORT_SYMBOL ( ath_rxbuf_alloc ) ;
2010-12-02 19:12:35 -08:00
2014-01-15 17:37:42 +01:00
bool ath_is_mybeacon ( struct ath_common * common , struct ieee80211_hdr * hdr )
{
return ieee80211_is_beacon ( hdr - > frame_control ) & &
! is_zero_ether_addr ( common - > curbssid ) & &
ether_addr_equal_64bits ( hdr - > addr3 , common - > curbssid ) ;
}
EXPORT_SYMBOL ( ath_is_mybeacon ) ;
2012-03-08 10:20:55 -08:00
void ath_printk ( const char * level , const struct ath_common * common ,
const char * fmt , . . . )
2010-12-02 19:12:35 -08:00
{
struct va_format vaf ;
va_list args ;
va_start ( args , fmt ) ;
vaf . fmt = fmt ;
vaf . va = & args ;
2014-10-07 10:14:36 +05:30
if ( common & & common - > hw & & common - > hw - > wiphy ) {
2012-03-08 10:20:55 -08:00
printk ( " %sath: %s: %pV " ,
level , wiphy_name ( common - > hw - > wiphy ) , & vaf ) ;
2014-10-07 10:14:36 +05:30
trace_ath_log ( common - > hw - > wiphy , & vaf ) ;
} else {
2012-03-08 10:20:55 -08:00
printk ( " %sath: %pV " , level , & vaf ) ;
2014-10-07 10:14:36 +05:30
}
2014-09-27 13:27:45 +05:30
2010-12-02 19:12:35 -08:00
va_end ( args ) ;
}
EXPORT_SYMBOL ( ath_printk ) ;