2009-04-23 20:52:52 +04:00
# ifndef __MAC80211_DRIVER_OPS
# define __MAC80211_DRIVER_OPS
# include <net/mac80211.h>
# include "ieee80211_i.h"
2009-07-07 15:46:22 +04:00
# include "driver-trace.h"
2009-04-23 20:52:52 +04: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 16:44:45 +04:00
int ret ;
2009-12-23 15:15:47 +03:00
might_sleep ( ) ;
2010-06-10 12:56:20 +04:00
trace_drv_start ( local ) ;
2009-08-21 16:44:45 +04:00
local - > started = true ;
smp_mb ( ) ;
ret = local - > ops - > start ( & local - > hw ) ;
2010-06-10 12:56:20 +04:00
trace_drv_return_int ( local , ret ) ;
2009-07-07 15:46:22 +04:00
return ret ;
2009-04-23 20:52:52 +04:00
}
static inline void drv_stop ( struct ieee80211_local * local )
{
2009-12-23 15:15:47 +03:00
might_sleep ( ) ;
2009-07-07 15:46:22 +04:00
trace_drv_stop ( local ) ;
2010-06-10 12:56:20 +04:00
local - > ops - > stop ( & local - > hw ) ;
trace_drv_return_void ( local ) ;
2009-08-21 16:44:45 +04: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 20:52:52 +04:00
}
static inline int drv_add_interface ( struct ieee80211_local * local ,
2009-12-23 15:15:45 +03:00
struct ieee80211_vif * vif )
2009-04-23 20:52:52 +04:00
{
2009-12-23 15:15:47 +03:00
int ret ;
might_sleep ( ) ;
2010-06-10 12:56:20 +04:00
trace_drv_add_interface ( local , vif_to_sdata ( vif ) ) ;
2009-12-23 15:15:47 +03:00
ret = local - > ops - > add_interface ( & local - > hw , vif ) ;
2010-06-10 12:56:20 +04:00
trace_drv_return_int ( local , ret ) ;
2009-07-07 15:46:22 +04:00
return ret ;
2009-04-23 20:52:52 +04:00
}
2010-08-27 14:35:58 +04:00
static inline int drv_change_interface ( struct ieee80211_local * local ,
struct ieee80211_sub_if_data * sdata ,
2010-09-16 16:58:23 +04:00
enum nl80211_iftype type , bool p2p )
2010-08-27 14:35:58 +04:00
{
int ret ;
might_sleep ( ) ;
2010-09-16 16:58:23 +04:00
trace_drv_change_interface ( local , sdata , type , p2p ) ;
ret = local - > ops - > change_interface ( & local - > hw , & sdata - > vif , type , p2p ) ;
2010-08-27 14:35:58 +04:00
trace_drv_return_int ( local , ret ) ;
return ret ;
}
2009-04-23 20:52:52 +04:00
static inline void drv_remove_interface ( struct ieee80211_local * local ,
2009-12-23 15:15:45 +03:00
struct ieee80211_vif * vif )
2009-04-23 20:52:52 +04:00
{
2009-12-23 15:15:47 +03:00
might_sleep ( ) ;
2009-12-23 15:15:45 +03:00
trace_drv_remove_interface ( local , vif_to_sdata ( vif ) ) ;
2010-06-10 12:56:20 +04:00
local - > ops - > remove_interface ( & local - > hw , vif ) ;
trace_drv_return_void ( local ) ;
2009-04-23 20:52:52 +04:00
}
static inline int drv_config ( struct ieee80211_local * local , u32 changed )
{
2009-12-23 15:15:47 +03:00
int ret ;
might_sleep ( ) ;
2010-06-10 12:56:20 +04:00
trace_drv_config ( local , changed ) ;
2009-12-23 15:15:47 +03:00
ret = local - > ops - > config ( & local - > hw , changed ) ;
2010-06-10 12:56:20 +04:00
trace_drv_return_int ( local , ret ) ;
2009-07-07 15:46:22 +04:00
return ret ;
2009-04-23 20:52:52 +04:00
}
static inline void drv_bss_info_changed ( struct ieee80211_local * local ,
2009-11-25 22:30:31 +03:00
struct ieee80211_sub_if_data * sdata ,
2009-04-23 20:52:52 +04:00
struct ieee80211_bss_conf * info ,
u32 changed )
{
2009-12-23 15:15:47 +03:00
might_sleep ( ) ;
2010-06-10 12:56:20 +04:00
trace_drv_bss_info_changed ( local , sdata , info , changed ) ;
2009-04-23 20:52:52 +04:00
if ( local - > ops - > bss_info_changed )
2009-11-25 22:30:31 +03:00
local - > ops - > bss_info_changed ( & local - > hw , & sdata - > vif , info , changed ) ;
2010-06-10 12:56:20 +04:00
trace_drv_return_void ( local ) ;
2009-04-23 20:52:52 +04:00
}
2009-08-17 18:16:53 +04:00
static inline u64 drv_prepare_multicast ( struct ieee80211_local * local ,
2010-04-02 01:22:57 +04:00
struct netdev_hw_addr_list * mc_list )
2009-08-17 18:16:53 +04:00
{
u64 ret = 0 ;
2010-06-10 12:56:20 +04:00
trace_drv_prepare_multicast ( local , mc_list - > count ) ;
2009-08-17 18:16:53 +04:00
if ( local - > ops - > prepare_multicast )
2010-04-02 01:22:57 +04:00
ret = local - > ops - > prepare_multicast ( & local - > hw , mc_list ) ;
2009-08-17 18:16:53 +04:00
2010-06-10 12:56:20 +04:00
trace_drv_return_u64 ( local , ret ) ;
2009-08-17 18:16:53 +04:00
return ret ;
}
2009-04-23 20:52:52 +04:00
static inline void drv_configure_filter ( struct ieee80211_local * local ,
unsigned int changed_flags ,
unsigned int * total_flags ,
2009-08-17 18:16:53 +04:00
u64 multicast )
2009-04-23 20:52:52 +04:00
{
2009-08-17 18:16:53 +04:00
might_sleep ( ) ;
2009-07-07 15:46:22 +04:00
trace_drv_configure_filter ( local , changed_flags , total_flags ,
2009-08-17 18:16:53 +04:00
multicast ) ;
2010-06-10 12:56:20 +04:00
local - > ops - > configure_filter ( & local - > hw , changed_flags , total_flags ,
multicast ) ;
trace_drv_return_void ( local ) ;
2009-04-23 20:52:52 +04:00
}
static inline int drv_set_tim ( struct ieee80211_local * local ,
struct ieee80211_sta * sta , bool set )
{
2009-07-07 15:46:22 +04:00
int ret = 0 ;
2010-06-10 12:56:20 +04:00
trace_drv_set_tim ( local , sta , set ) ;
2009-04-23 20:52:52 +04:00
if ( local - > ops - > set_tim )
2009-07-07 15:46:22 +04:00
ret = local - > ops - > set_tim ( & local - > hw , sta , set ) ;
2010-06-10 12:56:20 +04:00
trace_drv_return_int ( local , ret ) ;
2009-07-07 15:46:22 +04:00
return ret ;
2009-04-23 20:52:52 +04:00
}
static inline int drv_set_key ( struct ieee80211_local * local ,
2009-11-25 22:30:31 +03:00
enum set_key_cmd cmd ,
struct ieee80211_sub_if_data * sdata ,
2009-04-23 20:52:52 +04:00
struct ieee80211_sta * sta ,
struct ieee80211_key_conf * key )
{
2009-12-23 15:15:47 +03:00
int ret ;
might_sleep ( ) ;
2010-06-10 12:56:20 +04:00
trace_drv_set_key ( local , cmd , sdata , sta , key ) ;
2009-12-23 15:15:47 +03:00
ret = local - > ops - > set_key ( & local - > hw , cmd , & sdata - > vif , sta , key ) ;
2010-06-10 12:56:20 +04:00
trace_drv_return_int ( local , ret ) ;
2009-07-07 15:46:22 +04:00
return ret ;
2009-04-23 20:52:52 +04:00
}
static inline void drv_update_tkip_key ( struct ieee80211_local * local ,
2010-01-21 13:40:47 +03:00
struct ieee80211_sub_if_data * sdata ,
2009-04-23 20:52:52 +04:00
struct ieee80211_key_conf * conf ,
2010-01-21 13:40:47 +03:00
struct sta_info * sta , u32 iv32 ,
2009-04-23 20:52:52 +04:00
u16 * phase1key )
{
2010-01-21 13:40:47 +03:00
struct ieee80211_sta * ista = NULL ;
if ( sta )
ista = & sta - > sta ;
2010-06-10 12:56:20 +04:00
trace_drv_update_tkip_key ( local , sdata , conf , ista , iv32 ) ;
2009-04-23 20:52:52 +04:00
if ( local - > ops - > update_tkip_key )
2010-01-21 13:40:47 +03:00
local - > ops - > update_tkip_key ( & local - > hw , & sdata - > vif , conf ,
ista , iv32 , phase1key ) ;
2010-06-10 12:56:20 +04:00
trace_drv_return_void ( local ) ;
2009-04-23 20:52:52 +04:00
}
static inline int drv_hw_scan ( struct ieee80211_local * local ,
2010-04-27 13:59:34 +04:00
struct ieee80211_sub_if_data * sdata ,
2009-04-23 20:52:52 +04:00
struct cfg80211_scan_request * req )
{
2009-12-23 15:15:47 +03:00
int ret ;
might_sleep ( ) ;
2010-06-10 12:56:20 +04:00
trace_drv_hw_scan ( local , sdata , req ) ;
2010-04-27 13:59:34 +04:00
ret = local - > ops - > hw_scan ( & local - > hw , & sdata - > vif , req ) ;
2010-06-10 12:56:20 +04:00
trace_drv_return_int ( local , ret ) ;
2009-07-07 15:46:22 +04:00
return ret ;
2009-04-23 20:52:52 +04:00
}
static inline void drv_sw_scan_start ( struct ieee80211_local * local )
{
2009-12-23 15:15:47 +03:00
might_sleep ( ) ;
2010-06-10 12:56:20 +04:00
trace_drv_sw_scan_start ( local ) ;
2009-04-23 20:52:52 +04:00
if ( local - > ops - > sw_scan_start )
local - > ops - > sw_scan_start ( & local - > hw ) ;
2010-06-10 12:56:20 +04:00
trace_drv_return_void ( local ) ;
2009-04-23 20:52:52 +04:00
}
static inline void drv_sw_scan_complete ( struct ieee80211_local * local )
{
2009-12-23 15:15:47 +03:00
might_sleep ( ) ;
2010-06-10 12:56:20 +04:00
trace_drv_sw_scan_complete ( local ) ;
2009-04-23 20:52:52 +04:00
if ( local - > ops - > sw_scan_complete )
local - > ops - > sw_scan_complete ( & local - > hw ) ;
2010-06-10 12:56:20 +04:00
trace_drv_return_void ( local ) ;
2009-04-23 20:52:52 +04:00
}
static inline int drv_get_stats ( struct ieee80211_local * local ,
struct ieee80211_low_level_stats * stats )
{
2009-07-07 15:46:22 +04:00
int ret = - EOPNOTSUPP ;
2009-12-23 15:15:47 +03:00
might_sleep ( ) ;
2009-07-07 15:46:22 +04:00
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 20:52:52 +04: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 15:46:22 +04:00
trace_drv_get_tkip_seq ( local , hw_key_idx , iv32 , iv16 ) ;
2009-04-23 20:52:52 +04:00
}
static inline int drv_set_rts_threshold ( struct ieee80211_local * local ,
u32 value )
{
2009-07-07 15:46:22 +04:00
int ret = 0 ;
2009-12-23 15:15:47 +03:00
might_sleep ( ) ;
2010-06-10 12:56:20 +04:00
trace_drv_set_rts_threshold ( local , value ) ;
2009-04-23 20:52:52 +04:00
if ( local - > ops - > set_rts_threshold )
2009-07-07 15:46:22 +04:00
ret = local - > ops - > set_rts_threshold ( & local - > hw , value ) ;
2010-06-10 12:56:20 +04:00
trace_drv_return_int ( local , ret ) ;
2009-07-07 15:46:22 +04:00
return ret ;
2009-04-23 20:52:52 +04:00
}
2009-12-22 00:50:48 +03:00
static inline int drv_set_coverage_class ( struct ieee80211_local * local ,
u8 value )
{
int ret = 0 ;
might_sleep ( ) ;
2010-06-10 12:56:20 +04:00
trace_drv_set_coverage_class ( local , value ) ;
2009-12-22 00:50:48 +03:00
if ( local - > ops - > set_coverage_class )
local - > ops - > set_coverage_class ( & local - > hw , value ) ;
else
ret = - EOPNOTSUPP ;
2010-06-10 12:56:20 +04:00
trace_drv_return_int ( local , ret ) ;
2009-12-22 00:50:48 +03:00
return ret ;
}
2009-04-23 20:52:52 +04:00
static inline void drv_sta_notify ( struct ieee80211_local * local ,
2009-11-25 22:30:31 +03:00
struct ieee80211_sub_if_data * sdata ,
2009-04-23 20:52:52 +04:00
enum sta_notify_cmd cmd ,
struct ieee80211_sta * sta )
{
2010-06-10 12:56:20 +04:00
trace_drv_sta_notify ( local , sdata , cmd , sta ) ;
2009-04-23 20:52:52 +04:00
if ( local - > ops - > sta_notify )
2009-11-25 22:30:31 +03:00
local - > ops - > sta_notify ( & local - > hw , & sdata - > vif , cmd , sta ) ;
2010-06-10 12:56:20 +04:00
trace_drv_return_void ( local ) ;
2009-04-23 20:52:52 +04:00
}
2010-02-03 15:59:58 +03:00
static inline int drv_sta_add ( struct ieee80211_local * local ,
struct ieee80211_sub_if_data * sdata ,
struct ieee80211_sta * sta )
{
int ret = 0 ;
might_sleep ( ) ;
2010-06-10 12:56:20 +04:00
trace_drv_sta_add ( local , sdata , sta ) ;
2010-02-03 15:59:58 +03:00
if ( local - > ops - > sta_add )
ret = local - > ops - > sta_add ( & local - > hw , & sdata - > vif , sta ) ;
2010-06-10 12:56:20 +04:00
trace_drv_return_int ( local , ret ) ;
2010-02-03 15:59:58 +03:00
return ret ;
}
static inline void drv_sta_remove ( struct ieee80211_local * local ,
struct ieee80211_sub_if_data * sdata ,
struct ieee80211_sta * sta )
{
might_sleep ( ) ;
2010-06-10 12:56:20 +04:00
trace_drv_sta_remove ( local , sdata , sta ) ;
2010-02-03 15:59:58 +03:00
if ( local - > ops - > sta_remove )
local - > ops - > sta_remove ( & local - > hw , & sdata - > vif , sta ) ;
2010-06-10 12:56:20 +04:00
trace_drv_return_void ( local ) ;
2010-02-03 15:59:58 +03:00
}
2009-04-23 20:52:52 +04:00
static inline int drv_conf_tx ( struct ieee80211_local * local , u16 queue ,
const struct ieee80211_tx_queue_params * params )
{
2009-07-07 15:46:22 +04:00
int ret = - EOPNOTSUPP ;
2009-12-23 15:15:47 +03:00
might_sleep ( ) ;
2010-06-10 12:56:20 +04:00
trace_drv_conf_tx ( local , queue , params ) ;
2009-04-23 20:52:52 +04:00
if ( local - > ops - > conf_tx )
2009-07-07 15:46:22 +04:00
ret = local - > ops - > conf_tx ( & local - > hw , queue , params ) ;
2010-06-10 12:56:20 +04:00
trace_drv_return_int ( local , ret ) ;
2009-07-07 15:46:22 +04:00
return ret ;
2009-04-23 20:52:52 +04:00
}
static inline u64 drv_get_tsf ( struct ieee80211_local * local )
{
2009-07-07 15:46:22 +04:00
u64 ret = - 1ULL ;
2009-12-23 15:15:47 +03:00
might_sleep ( ) ;
2010-06-10 12:56:20 +04:00
trace_drv_get_tsf ( local ) ;
2009-04-23 20:52:52 +04:00
if ( local - > ops - > get_tsf )
2009-07-07 15:46:22 +04:00
ret = local - > ops - > get_tsf ( & local - > hw ) ;
2010-06-10 12:56:20 +04:00
trace_drv_return_u64 ( local , ret ) ;
2009-07-07 15:46:22 +04:00
return ret ;
2009-04-23 20:52:52 +04:00
}
static inline void drv_set_tsf ( struct ieee80211_local * local , u64 tsf )
{
2009-12-23 15:15:47 +03:00
might_sleep ( ) ;
2010-06-10 12:56:20 +04:00
trace_drv_set_tsf ( local , tsf ) ;
2009-04-23 20:52:52 +04:00
if ( local - > ops - > set_tsf )
local - > ops - > set_tsf ( & local - > hw , tsf ) ;
2010-06-10 12:56:20 +04:00
trace_drv_return_void ( local ) ;
2009-04-23 20:52:52 +04:00
}
static inline void drv_reset_tsf ( struct ieee80211_local * local )
{
2009-12-23 15:15:47 +03:00
might_sleep ( ) ;
2010-06-10 12:56:20 +04:00
trace_drv_reset_tsf ( local ) ;
2009-04-23 20:52:52 +04:00
if ( local - > ops - > reset_tsf )
local - > ops - > reset_tsf ( & local - > hw ) ;
2010-06-10 12:56:20 +04:00
trace_drv_return_void ( local ) ;
2009-04-23 20:52:52 +04:00
}
static inline int drv_tx_last_beacon ( struct ieee80211_local * local )
{
2009-07-07 15:46:22 +04:00
int ret = 1 ;
2009-12-23 15:15:47 +03:00
might_sleep ( ) ;
2010-06-10 12:56:20 +04:00
trace_drv_tx_last_beacon ( local ) ;
2009-04-23 20:52:52 +04:00
if ( local - > ops - > tx_last_beacon )
2009-07-07 15:46:22 +04:00
ret = local - > ops - > tx_last_beacon ( & local - > hw ) ;
2010-06-10 12:56:20 +04:00
trace_drv_return_int ( local , ret ) ;
2009-07-07 15:46:22 +04:00
return ret ;
2009-04-23 20:52:52 +04:00
}
static inline int drv_ampdu_action ( struct ieee80211_local * local ,
2009-11-25 22:30:31 +03:00
struct ieee80211_sub_if_data * sdata ,
2009-04-23 20:52:52 +04:00
enum ieee80211_ampdu_mlme_action action ,
struct ieee80211_sta * sta , u16 tid ,
u16 * ssn )
{
2009-07-07 15:46:22 +04:00
int ret = - EOPNOTSUPP ;
2010-06-10 12:21:48 +04:00
might_sleep ( ) ;
2010-06-10 12:56:20 +04:00
trace_drv_ampdu_action ( local , sdata , action , sta , tid , ssn ) ;
2009-04-23 20:52:52 +04:00
if ( local - > ops - > ampdu_action )
2009-11-25 22:30:31 +03:00
ret = local - > ops - > ampdu_action ( & local - > hw , & sdata - > vif , action ,
2009-07-07 15:46:22 +04:00
sta , tid , ssn ) ;
2010-06-10 12:21:49 +04:00
2010-06-10 12:56:20 +04:00
trace_drv_return_int ( local , ret ) ;
2009-07-07 15:46:22 +04:00
return ret ;
2009-04-23 20:52:52 +04:00
}
2009-06-02 15:01:41 +04:00
2010-04-19 12:23:57 +04:00
static inline int drv_get_survey ( struct ieee80211_local * local , int idx ,
struct survey_info * survey )
{
int ret = - EOPNOTSUPP ;
2010-06-29 22:51:23 +04:00
trace_drv_get_survey ( local , idx , survey ) ;
2010-06-07 18:33:49 +04:00
if ( local - > ops - > get_survey )
2010-04-19 12:23:57 +04:00
ret = local - > ops - > get_survey ( & local - > hw , idx , survey ) ;
2010-06-29 22:51:23 +04:00
trace_drv_return_int ( local , ret ) ;
2010-04-19 12:23:57 +04:00
return ret ;
}
2009-06-02 15:01:41 +04:00
static inline void drv_rfkill_poll ( struct ieee80211_local * local )
{
2009-12-23 15:15:47 +03:00
might_sleep ( ) ;
2009-06-02 15:01:41 +04:00
if ( local - > ops - > rfkill_poll )
local - > ops - > rfkill_poll ( & local - > hw ) ;
}
2009-12-23 15:15:32 +03:00
static inline void drv_flush ( struct ieee80211_local * local , bool drop )
{
2009-12-23 15:15:47 +03:00
might_sleep ( ) ;
2009-12-23 15:15:32 +03:00
trace_drv_flush ( local , drop ) ;
if ( local - > ops - > flush )
local - > ops - > flush ( & local - > hw , drop ) ;
2010-06-10 12:56:20 +04:00
trace_drv_return_void ( local ) ;
2009-12-23 15:15:32 +03:00
}
2010-05-11 18:20:57 +04:00
static inline void drv_channel_switch ( struct ieee80211_local * local ,
struct ieee80211_channel_switch * ch_switch )
{
might_sleep ( ) ;
trace_drv_channel_switch ( local , ch_switch ) ;
2010-06-10 12:56:20 +04:00
local - > ops - > channel_switch ( & local - > hw , ch_switch ) ;
trace_drv_return_void ( local ) ;
2010-05-11 18:20:57 +04:00
}
2009-04-23 20:52:52 +04:00
# endif /* __MAC80211_DRIVER_OPS */