2009-04-23 18:52:52 +02:00
# ifndef __MAC80211_DRIVER_OPS
# define __MAC80211_DRIVER_OPS
# include <net/mac80211.h>
# include "ieee80211_i.h"
2009-07-07 13:46:22 +02:00
# include "driver-trace.h"
2009-04-23 18:52:52 +02:00
static inline int drv_tx ( struct ieee80211_local * local , struct sk_buff * skb )
{
return local - > ops - > tx ( & local - > hw , skb ) ;
}
static inline int drv_start ( struct ieee80211_local * local )
{
2009-08-21 14:44:45 +02:00
int ret ;
local - > started = true ;
smp_mb ( ) ;
ret = local - > ops - > start ( & local - > hw ) ;
2009-07-07 13:46:22 +02:00
trace_drv_start ( local , ret ) ;
return ret ;
2009-04-23 18:52:52 +02:00
}
static inline void drv_stop ( struct ieee80211_local * local )
{
local - > ops - > stop ( & local - > hw ) ;
2009-07-07 13:46:22 +02:00
trace_drv_stop ( local ) ;
2009-08-21 14:44:45 +02:00
/* sync away all work on the tasklet before clearing started */
tasklet_disable ( & local - > tasklet ) ;
tasklet_enable ( & local - > tasklet ) ;
barrier ( ) ;
local - > started = false ;
2009-04-23 18:52:52 +02:00
}
static inline int drv_add_interface ( struct ieee80211_local * local ,
struct ieee80211_if_init_conf * conf )
{
2009-07-07 13:46:22 +02:00
int ret = local - > ops - > add_interface ( & local - > hw , conf ) ;
trace_drv_add_interface ( local , conf - > mac_addr , conf - > vif , ret ) ;
return ret ;
2009-04-23 18:52:52 +02:00
}
static inline void drv_remove_interface ( struct ieee80211_local * local ,
struct ieee80211_if_init_conf * conf )
{
local - > ops - > remove_interface ( & local - > hw , conf ) ;
2009-07-07 13:46:22 +02:00
trace_drv_remove_interface ( local , conf - > mac_addr , conf - > vif ) ;
2009-04-23 18:52:52 +02:00
}
static inline int drv_config ( struct ieee80211_local * local , u32 changed )
{
2009-07-07 13:46:22 +02:00
int ret = local - > ops - > config ( & local - > hw , changed ) ;
trace_drv_config ( local , changed , ret ) ;
return ret ;
2009-04-23 18:52:52 +02:00
}
static inline void drv_bss_info_changed ( struct ieee80211_local * local ,
struct ieee80211_vif * vif ,
struct ieee80211_bss_conf * info ,
u32 changed )
{
if ( local - > ops - > bss_info_changed )
local - > ops - > bss_info_changed ( & local - > hw , vif , info , changed ) ;
2009-07-07 13:46:22 +02:00
trace_drv_bss_info_changed ( local , vif , info , changed ) ;
2009-04-23 18:52:52 +02:00
}
2009-08-17 16:16:53 +02:00
static inline u64 drv_prepare_multicast ( struct ieee80211_local * local ,
int mc_count ,
struct dev_addr_list * mc_list )
{
u64 ret = 0 ;
if ( local - > ops - > prepare_multicast )
ret = local - > ops - > prepare_multicast ( & local - > hw , mc_count ,
mc_list ) ;
trace_drv_prepare_multicast ( local , mc_count , ret ) ;
return ret ;
}
2009-04-23 18:52:52 +02:00
static inline void drv_configure_filter ( struct ieee80211_local * local ,
unsigned int changed_flags ,
unsigned int * total_flags ,
2009-08-17 16:16:53 +02:00
u64 multicast )
2009-04-23 18:52:52 +02:00
{
2009-08-17 16:16:53 +02:00
might_sleep ( ) ;
2009-04-23 18:52:52 +02:00
local - > ops - > configure_filter ( & local - > hw , changed_flags , total_flags ,
2009-08-17 16:16:53 +02:00
multicast ) ;
2009-07-07 13:46:22 +02:00
trace_drv_configure_filter ( local , changed_flags , total_flags ,
2009-08-17 16:16:53 +02:00
multicast ) ;
2009-04-23 18:52:52 +02:00
}
static inline int drv_set_tim ( struct ieee80211_local * local ,
struct ieee80211_sta * sta , bool set )
{
2009-07-07 13:46:22 +02:00
int ret = 0 ;
2009-04-23 18:52:52 +02:00
if ( local - > ops - > set_tim )
2009-07-07 13:46:22 +02:00
ret = local - > ops - > set_tim ( & local - > hw , sta , set ) ;
trace_drv_set_tim ( local , sta , set , ret ) ;
return ret ;
2009-04-23 18:52:52 +02:00
}
static inline int drv_set_key ( struct ieee80211_local * local ,
enum set_key_cmd cmd , struct ieee80211_vif * vif ,
struct ieee80211_sta * sta ,
struct ieee80211_key_conf * key )
{
2009-07-07 13:46:22 +02:00
int ret = local - > ops - > set_key ( & local - > hw , cmd , vif , sta , key ) ;
trace_drv_set_key ( local , cmd , vif , sta , key , ret ) ;
return ret ;
2009-04-23 18:52:52 +02:00
}
static inline void drv_update_tkip_key ( struct ieee80211_local * local ,
struct ieee80211_key_conf * conf ,
const u8 * address , u32 iv32 ,
u16 * phase1key )
{
if ( local - > ops - > update_tkip_key )
local - > ops - > update_tkip_key ( & local - > hw , conf , address ,
iv32 , phase1key ) ;
2009-07-07 13:46:22 +02:00
trace_drv_update_tkip_key ( local , conf , address , iv32 ) ;
2009-04-23 18:52:52 +02:00
}
static inline int drv_hw_scan ( struct ieee80211_local * local ,
struct cfg80211_scan_request * req )
{
2009-07-07 13:46:22 +02:00
int ret = local - > ops - > hw_scan ( & local - > hw , req ) ;
trace_drv_hw_scan ( local , req , ret ) ;
return ret ;
2009-04-23 18:52:52 +02:00
}
static inline void drv_sw_scan_start ( struct ieee80211_local * local )
{
if ( local - > ops - > sw_scan_start )
local - > ops - > sw_scan_start ( & local - > hw ) ;
2009-07-07 13:46:22 +02:00
trace_drv_sw_scan_start ( local ) ;
2009-04-23 18:52:52 +02:00
}
static inline void drv_sw_scan_complete ( struct ieee80211_local * local )
{
if ( local - > ops - > sw_scan_complete )
local - > ops - > sw_scan_complete ( & local - > hw ) ;
2009-07-07 13:46:22 +02:00
trace_drv_sw_scan_complete ( local ) ;
2009-04-23 18:52:52 +02:00
}
static inline int drv_get_stats ( struct ieee80211_local * local ,
struct ieee80211_low_level_stats * stats )
{
2009-07-07 13:46:22 +02:00
int ret = - EOPNOTSUPP ;
if ( local - > ops - > get_stats )
ret = local - > ops - > get_stats ( & local - > hw , stats ) ;
trace_drv_get_stats ( local , stats , ret ) ;
return ret ;
2009-04-23 18:52:52 +02:00
}
static inline void drv_get_tkip_seq ( struct ieee80211_local * local ,
u8 hw_key_idx , u32 * iv32 , u16 * iv16 )
{
if ( local - > ops - > get_tkip_seq )
local - > ops - > get_tkip_seq ( & local - > hw , hw_key_idx , iv32 , iv16 ) ;
2009-07-07 13:46:22 +02:00
trace_drv_get_tkip_seq ( local , hw_key_idx , iv32 , iv16 ) ;
2009-04-23 18:52:52 +02:00
}
static inline int drv_set_rts_threshold ( struct ieee80211_local * local ,
u32 value )
{
2009-07-07 13:46:22 +02:00
int ret = 0 ;
2009-04-23 18:52:52 +02:00
if ( local - > ops - > set_rts_threshold )
2009-07-07 13:46:22 +02:00
ret = local - > ops - > set_rts_threshold ( & local - > hw , value ) ;
trace_drv_set_rts_threshold ( local , value , ret ) ;
return ret ;
2009-04-23 18:52:52 +02:00
}
static inline void drv_sta_notify ( struct ieee80211_local * local ,
struct ieee80211_vif * vif ,
enum sta_notify_cmd cmd ,
struct ieee80211_sta * sta )
{
if ( local - > ops - > sta_notify )
local - > ops - > sta_notify ( & local - > hw , vif , cmd , sta ) ;
2009-07-07 13:46:22 +02:00
trace_drv_sta_notify ( local , vif , cmd , sta ) ;
2009-04-23 18:52:52 +02:00
}
static inline int drv_conf_tx ( struct ieee80211_local * local , u16 queue ,
const struct ieee80211_tx_queue_params * params )
{
2009-07-07 13:46:22 +02:00
int ret = - EOPNOTSUPP ;
2009-04-23 18:52:52 +02:00
if ( local - > ops - > conf_tx )
2009-07-07 13:46:22 +02:00
ret = local - > ops - > conf_tx ( & local - > hw , queue , params ) ;
trace_drv_conf_tx ( local , queue , params , ret ) ;
return ret ;
2009-04-23 18:52:52 +02:00
}
static inline int drv_get_tx_stats ( struct ieee80211_local * local ,
struct ieee80211_tx_queue_stats * stats )
{
2009-07-07 13:46:22 +02:00
int ret = local - > ops - > get_tx_stats ( & local - > hw , stats ) ;
trace_drv_get_tx_stats ( local , stats , ret ) ;
return ret ;
2009-04-23 18:52:52 +02:00
}
static inline u64 drv_get_tsf ( struct ieee80211_local * local )
{
2009-07-07 13:46:22 +02:00
u64 ret = - 1ULL ;
2009-04-23 18:52:52 +02:00
if ( local - > ops - > get_tsf )
2009-07-07 13:46:22 +02:00
ret = local - > ops - > get_tsf ( & local - > hw ) ;
trace_drv_get_tsf ( local , ret ) ;
return ret ;
2009-04-23 18:52:52 +02:00
}
static inline void drv_set_tsf ( struct ieee80211_local * local , u64 tsf )
{
if ( local - > ops - > set_tsf )
local - > ops - > set_tsf ( & local - > hw , tsf ) ;
2009-07-07 13:46:22 +02:00
trace_drv_set_tsf ( local , tsf ) ;
2009-04-23 18:52:52 +02:00
}
static inline void drv_reset_tsf ( struct ieee80211_local * local )
{
if ( local - > ops - > reset_tsf )
local - > ops - > reset_tsf ( & local - > hw ) ;
2009-07-07 13:46:22 +02:00
trace_drv_reset_tsf ( local ) ;
2009-04-23 18:52:52 +02:00
}
static inline int drv_tx_last_beacon ( struct ieee80211_local * local )
{
2009-07-07 13:46:22 +02:00
int ret = 1 ;
2009-04-23 18:52:52 +02:00
if ( local - > ops - > tx_last_beacon )
2009-07-07 13:46:22 +02:00
ret = local - > ops - > tx_last_beacon ( & local - > hw ) ;
trace_drv_tx_last_beacon ( local , ret ) ;
return ret ;
2009-04-23 18:52:52 +02:00
}
static inline int drv_ampdu_action ( struct ieee80211_local * local ,
2009-11-16 12:00:38 +01:00
struct ieee80211_vif * vif ,
2009-04-23 18:52:52 +02:00
enum ieee80211_ampdu_mlme_action action ,
struct ieee80211_sta * sta , u16 tid ,
u16 * ssn )
{
2009-07-07 13:46:22 +02:00
int ret = - EOPNOTSUPP ;
2009-04-23 18:52:52 +02:00
if ( local - > ops - > ampdu_action )
2009-11-16 12:00:38 +01:00
ret = local - > ops - > ampdu_action ( & local - > hw , vif , action ,
2009-07-07 13:46:22 +02:00
sta , tid , ssn ) ;
2009-11-16 12:00:38 +01:00
trace_drv_ampdu_action ( local , vif , action , sta , tid , ssn , ret ) ;
2009-07-07 13:46:22 +02:00
return ret ;
2009-04-23 18:52:52 +02:00
}
2009-06-02 13:01:41 +02:00
static inline void drv_rfkill_poll ( struct ieee80211_local * local )
{
if ( local - > ops - > rfkill_poll )
local - > ops - > rfkill_poll ( & local - > hw ) ;
}
2009-04-23 18:52:52 +02:00
# endif /* __MAC80211_DRIVER_OPS */