2015-03-19 21:23:40 +08:00
# ifndef __MAC802154_DRIVER_OPS
2014-10-28 18:21:20 +01:00
# define __MAC802154_DRIVER_OPS
# include <linux/types.h>
# include <linux/rtnetlink.h>
# include <net/mac802154.h>
# include "ieee802154_i.h"
2015-06-01 14:22:26 +05:30
# include "trace.h"
2014-10-28 18:21:20 +01:00
static inline int
drv_xmit_async ( struct ieee802154_local * local , struct sk_buff * skb )
{
return local - > ops - > xmit_async ( & local - > hw , skb ) ;
}
static inline int
drv_xmit_sync ( struct ieee802154_local * local , struct sk_buff * skb )
{
might_sleep ( ) ;
return local - > ops - > xmit_sync ( & local - > hw , skb ) ;
}
static inline int drv_start ( struct ieee802154_local * local )
{
2015-06-01 14:22:26 +05:30
int ret ;
2014-10-28 18:21:20 +01:00
might_sleep ( ) ;
2015-06-01 14:22:26 +05:30
trace_802154_drv_start ( local ) ;
2014-10-28 18:21:26 +01:00
local - > started = true ;
2014-10-28 18:21:27 +01:00
smp_mb ( ) ;
2015-06-01 14:22:26 +05:30
ret = local - > ops - > start ( & local - > hw ) ;
trace_802154_drv_return_int ( local , ret ) ;
return ret ;
2014-10-28 18:21:20 +01:00
}
static inline void drv_stop ( struct ieee802154_local * local )
{
might_sleep ( ) ;
2015-06-01 14:22:26 +05:30
trace_802154_drv_stop ( local ) ;
2014-10-28 18:21:20 +01:00
local - > ops - > stop ( & local - > hw ) ;
2015-06-01 14:22:26 +05:30
trace_802154_drv_return_void ( local ) ;
2014-10-28 18:21:26 +01:00
2014-10-28 18:21:27 +01:00
/* sync away all work on the tasklet before clearing started */
tasklet_disable ( & local - > tasklet ) ;
tasklet_enable ( & local - > tasklet ) ;
barrier ( ) ;
2014-10-28 18:21:26 +01:00
local - > started = false ;
2014-10-28 18:21:20 +01:00
}
2014-11-17 08:20:45 +01:00
static inline int
drv_set_channel ( struct ieee802154_local * local , u8 page , u8 channel )
2014-10-28 18:21:20 +01:00
{
2015-06-01 14:22:26 +05:30
int ret ;
2014-10-28 18:21:20 +01:00
might_sleep ( ) ;
2015-06-01 14:22:26 +05:30
trace_802154_drv_set_channel ( local , page , channel ) ;
ret = local - > ops - > set_channel ( & local - > hw , page , channel ) ;
trace_802154_drv_return_int ( local , ret ) ;
return ret ;
2014-10-28 18:21:20 +01:00
}
2015-05-17 21:44:40 +02:00
static inline int drv_set_tx_power ( struct ieee802154_local * local , s32 mbm )
2014-10-28 18:21:20 +01:00
{
2015-06-01 14:22:26 +05:30
int ret ;
2014-10-28 18:21:20 +01:00
might_sleep ( ) ;
if ( ! local - > ops - > set_txpower ) {
WARN_ON ( 1 ) ;
return - EOPNOTSUPP ;
}
2015-06-01 14:22:26 +05:30
trace_802154_drv_set_tx_power ( local , mbm ) ;
ret = local - > ops - > set_txpower ( & local - > hw , mbm ) ;
trace_802154_drv_return_int ( local , ret ) ;
return ret ;
2014-10-28 18:21:20 +01:00
}
2014-12-10 15:33:12 +01:00
static inline int drv_set_cca_mode ( struct ieee802154_local * local ,
const struct wpan_phy_cca * cca )
2014-10-28 18:21:20 +01:00
{
2015-06-01 14:22:26 +05:30
int ret ;
2014-10-28 18:21:20 +01:00
might_sleep ( ) ;
if ( ! local - > ops - > set_cca_mode ) {
WARN_ON ( 1 ) ;
return - EOPNOTSUPP ;
}
2015-06-01 14:22:26 +05:30
trace_802154_drv_set_cca_mode ( local , cca ) ;
ret = local - > ops - > set_cca_mode ( & local - > hw , cca ) ;
trace_802154_drv_return_int ( local , ret ) ;
return ret ;
2014-10-28 18:21:20 +01:00
}
2014-11-17 08:20:45 +01:00
static inline int drv_set_lbt_mode ( struct ieee802154_local * local , bool mode )
2014-10-28 18:21:20 +01:00
{
2015-06-01 14:22:26 +05:30
int ret ;
2014-10-28 18:21:20 +01:00
might_sleep ( ) ;
if ( ! local - > ops - > set_lbt ) {
WARN_ON ( 1 ) ;
return - EOPNOTSUPP ;
}
2015-06-01 14:22:26 +05:30
trace_802154_drv_set_lbt_mode ( local , mode ) ;
ret = local - > ops - > set_lbt ( & local - > hw , mode ) ;
trace_802154_drv_return_int ( local , ret ) ;
return ret ;
2014-10-28 18:21:20 +01:00
}
2014-11-17 08:20:45 +01:00
static inline int
2015-05-17 21:44:41 +02:00
drv_set_cca_ed_level ( struct ieee802154_local * local , s32 mbm )
2014-10-28 18:21:20 +01:00
{
2015-06-01 14:22:26 +05:30
int ret ;
2014-10-28 18:21:20 +01:00
might_sleep ( ) ;
if ( ! local - > ops - > set_cca_ed_level ) {
WARN_ON ( 1 ) ;
return - EOPNOTSUPP ;
}
2015-06-01 14:22:26 +05:30
trace_802154_drv_set_cca_ed_level ( local , mbm ) ;
ret = local - > ops - > set_cca_ed_level ( & local - > hw , mbm ) ;
trace_802154_drv_return_int ( local , ret ) ;
return ret ;
2014-10-28 18:21:20 +01:00
}
2014-11-17 08:20:45 +01:00
static inline int drv_set_pan_id ( struct ieee802154_local * local , __le16 pan_id )
2014-10-28 18:21:20 +01:00
{
struct ieee802154_hw_addr_filt filt ;
2015-06-01 14:22:26 +05:30
int ret ;
2014-10-28 18:21:20 +01:00
might_sleep ( ) ;
if ( ! local - > ops - > set_hw_addr_filt ) {
WARN_ON ( 1 ) ;
return - EOPNOTSUPP ;
}
filt . pan_id = pan_id ;
2015-06-01 14:22:26 +05:30
trace_802154_drv_set_pan_id ( local , pan_id ) ;
ret = local - > ops - > set_hw_addr_filt ( & local - > hw , & filt ,
2014-10-28 18:21:20 +01:00
IEEE802154_AFILT_PANID_CHANGED ) ;
2015-06-01 14:22:26 +05:30
trace_802154_drv_return_int ( local , ret ) ;
return ret ;
2014-10-28 18:21:20 +01:00
}
2014-11-17 08:20:45 +01:00
static inline int
drv_set_extended_addr ( struct ieee802154_local * local , __le64 extended_addr )
2014-10-28 18:21:20 +01:00
{
struct ieee802154_hw_addr_filt filt ;
2015-06-01 14:22:26 +05:30
int ret ;
2014-10-28 18:21:20 +01:00
might_sleep ( ) ;
if ( ! local - > ops - > set_hw_addr_filt ) {
WARN_ON ( 1 ) ;
return - EOPNOTSUPP ;
}
filt . ieee_addr = extended_addr ;
2015-06-01 14:22:26 +05:30
trace_802154_drv_set_extended_addr ( local , extended_addr ) ;
ret = local - > ops - > set_hw_addr_filt ( & local - > hw , & filt ,
2014-10-28 18:21:20 +01:00
IEEE802154_AFILT_IEEEADDR_CHANGED ) ;
2015-06-01 14:22:26 +05:30
trace_802154_drv_return_int ( local , ret ) ;
return ret ;
2014-10-28 18:21:20 +01:00
}
2014-11-17 08:20:45 +01:00
static inline int
drv_set_short_addr ( struct ieee802154_local * local , __le16 short_addr )
2014-10-28 18:21:20 +01:00
{
struct ieee802154_hw_addr_filt filt ;
2015-06-01 14:22:26 +05:30
int ret ;
2014-10-28 18:21:20 +01:00
might_sleep ( ) ;
if ( ! local - > ops - > set_hw_addr_filt ) {
WARN_ON ( 1 ) ;
return - EOPNOTSUPP ;
}
filt . short_addr = short_addr ;
2015-06-01 14:22:26 +05:30
trace_802154_drv_set_short_addr ( local , short_addr ) ;
ret = local - > ops - > set_hw_addr_filt ( & local - > hw , & filt ,
2014-10-28 18:21:20 +01:00
IEEE802154_AFILT_SADDR_CHANGED ) ;
2015-06-01 14:22:26 +05:30
trace_802154_drv_return_int ( local , ret ) ;
return ret ;
2014-10-28 18:21:20 +01:00
}
2014-11-17 08:20:45 +01:00
static inline int
drv_set_pan_coord ( struct ieee802154_local * local , bool is_coord )
2014-10-28 18:21:20 +01:00
{
struct ieee802154_hw_addr_filt filt ;
2015-06-01 14:22:26 +05:30
int ret ;
2014-10-28 18:21:20 +01:00
might_sleep ( ) ;
if ( ! local - > ops - > set_hw_addr_filt ) {
WARN_ON ( 1 ) ;
return - EOPNOTSUPP ;
}
filt . pan_coord = is_coord ;
2015-06-01 14:22:26 +05:30
trace_802154_drv_set_pan_coord ( local , is_coord ) ;
ret = local - > ops - > set_hw_addr_filt ( & local - > hw , & filt ,
2014-10-28 18:21:20 +01:00
IEEE802154_AFILT_PANC_CHANGED ) ;
2015-06-01 14:22:26 +05:30
trace_802154_drv_return_int ( local , ret ) ;
return ret ;
2014-10-28 18:21:20 +01:00
}
2014-11-17 08:20:45 +01:00
static inline int
drv_set_csma_params ( struct ieee802154_local * local , u8 min_be , u8 max_be ,
u8 max_csma_backoffs )
2014-10-28 18:21:20 +01:00
{
2015-06-01 14:22:26 +05:30
int ret ;
2014-10-28 18:21:20 +01:00
might_sleep ( ) ;
if ( ! local - > ops - > set_csma_params ) {
WARN_ON ( 1 ) ;
return - EOPNOTSUPP ;
}
2015-06-01 14:22:26 +05:30
trace_802154_drv_set_csma_params ( local , min_be , max_be ,
max_csma_backoffs ) ;
ret = local - > ops - > set_csma_params ( & local - > hw , min_be , max_be ,
2014-10-28 18:21:20 +01:00
max_csma_backoffs ) ;
2015-06-01 14:22:26 +05:30
trace_802154_drv_return_int ( local , ret ) ;
return ret ;
2014-10-28 18:21:20 +01:00
}
2014-11-17 08:20:45 +01:00
static inline int
drv_set_max_frame_retries ( struct ieee802154_local * local , s8 max_frame_retries )
2014-10-28 18:21:20 +01:00
{
2015-06-01 14:22:26 +05:30
int ret ;
2014-10-28 18:21:20 +01:00
might_sleep ( ) ;
if ( ! local - > ops - > set_frame_retries ) {
WARN_ON ( 1 ) ;
return - EOPNOTSUPP ;
}
2015-06-01 14:22:26 +05:30
trace_802154_drv_set_max_frame_retries ( local , max_frame_retries ) ;
ret = local - > ops - > set_frame_retries ( & local - > hw , max_frame_retries ) ;
trace_802154_drv_return_int ( local , ret ) ;
return ret ;
2014-10-28 18:21:20 +01:00
}
2014-11-17 08:20:45 +01:00
static inline int
drv_set_promiscuous_mode ( struct ieee802154_local * local , bool on )
2014-10-29 21:34:32 +01:00
{
2015-06-01 14:22:26 +05:30
int ret ;
2014-10-29 21:34:32 +01:00
might_sleep ( ) ;
if ( ! local - > ops - > set_promiscuous_mode ) {
WARN_ON ( 1 ) ;
return - EOPNOTSUPP ;
}
2015-06-01 14:22:26 +05:30
trace_802154_drv_set_promiscuous_mode ( local , on ) ;
ret = local - > ops - > set_promiscuous_mode ( & local - > hw , on ) ;
trace_802154_drv_return_int ( local , ret ) ;
return ret ;
2014-10-29 21:34:32 +01:00
}
2015-03-19 21:23:40 +08:00
# endif /* __MAC802154_DRIVER_OPS */