2019-05-27 08:55:21 +02:00
/* SPDX-License-Identifier: GPL-2.0-only */
2012-05-15 20:50:20 +00:00
/*
* Copyright ( C ) 2007 - 2012 Siemens AG
*
* Written by :
* Pavel Smolenskiy < pavel . smolenskiy @ gmail . com >
* Maxim Gorbachyov < maxim . gorbachev @ siemens . com >
* Dmitry Eremin - Solenikov < dbaryshkov @ gmail . com >
* Alexander Smirnov < alex . bluesman . smirnov @ gmail . com >
*/
2014-10-25 09:41:00 +02:00
# ifndef __IEEE802154_I_H
# define __IEEE802154_I_H
2012-05-15 20:50:20 +00:00
2017-03-29 17:17:31 +02:00
# include <linux/interrupt.h>
2014-05-16 17:46:40 +02:00
# include <linux/mutex.h>
2014-11-12 19:51:56 +01:00
# include <linux/hrtimer.h>
2014-11-05 20:51:17 +01:00
# include <net/cfg802154.h>
2014-05-16 17:46:37 +02:00
# include <net/mac802154.h>
2014-11-17 08:20:49 +01:00
# include <net/nl802154.h>
2014-03-31 21:37:46 +02:00
# include <net/ieee802154_netdev.h>
2014-05-16 17:46:40 +02:00
# include "llsec.h"
2012-05-15 20:50:20 +00:00
/* mac802154 device private data */
2014-10-25 17:16:35 +02:00
struct ieee802154_local {
2014-10-25 17:16:34 +02:00
struct ieee802154_hw hw ;
2014-10-28 18:21:18 +01:00
const struct ieee802154_ops * ops ;
2012-05-15 20:50:20 +00:00
2022-10-07 10:53:05 +02:00
/* hardware address filter */
struct ieee802154_hw_addr_filt addr_filt ;
2012-05-15 20:50:20 +00:00
/* ieee802154 phy */
struct wpan_phy * phy ;
int open_count ;
/* As in mac80211 slaves list is modified:
* 1 ) under the RTNL
* 2 ) protected by slaves_mtx ;
* 3 ) in an RCU manner
*
* So atomic readers can use any of this protection methods .
*/
2014-10-25 17:16:38 +02:00
struct list_head interfaces ;
struct mutex iflist_mtx ;
2012-05-15 20:50:20 +00:00
/* This one is used for scanning and other jobs not to be interfered
* with serial driver .
*/
2014-10-25 17:16:41 +02:00
struct workqueue_struct * workqueue ;
2012-05-15 20:50:20 +00:00
2014-11-12 19:51:56 +01:00
struct hrtimer ifs_timer ;
2014-10-28 18:21:25 +01:00
bool started ;
2015-06-24 11:36:36 +02:00
bool suspended ;
2014-10-27 17:13:30 +01:00
struct tasklet_struct tasklet ;
struct sk_buff_head skb_queue ;
2015-07-21 17:44:47 +03:00
struct sk_buff * tx_skb ;
2022-05-19 17:05:07 +02:00
struct work_struct sync_tx_work ;
2022-04-07 12:08:56 +02:00
/* A negative Linux error code or a null/positive MLME error status */
int tx_result ;
2012-05-15 20:50:20 +00:00
} ;
2014-10-27 17:13:30 +01:00
enum {
IEEE802154_RX_MSG = 1 ,
} ;
2014-10-28 18:21:24 +01:00
enum ieee802154_sdata_state_bits {
SDATA_STATE_RUNNING ,
} ;
2012-05-15 20:50:24 +00:00
/* Slave interface definition.
*
* Slaves represent typical network interfaces available from userspace .
* Each ieee802154 device / transceiver may have several slaves and able
* to be associated with several networks at the same time .
*/
2014-10-25 17:16:36 +02:00
struct ieee802154_sub_if_data {
2012-05-15 20:50:24 +00:00
struct list_head list ; /* the ieee802154_priv->slaves list */
2014-11-05 20:51:17 +01:00
struct wpan_dev wpan_dev ;
2014-10-25 17:16:37 +02:00
struct ieee802154_local * local ;
2012-05-15 20:50:24 +00:00
struct net_device * dev ;
2022-10-07 10:53:05 +02:00
/* Each interface starts and works in nominal state at a given filtering
* level given by iface_default_filtering , which is set once for all at
* the interface creation and should not evolve over time . For some MAC
* operations however , the filtering level may change temporarily , as
* reflected in the required_filtering field . The actual filtering at
* the PHY level may be different and is shown in struct wpan_phy .
*/
enum ieee802154_filtering_level iface_default_filtering ;
enum ieee802154_filtering_level required_filtering ;
2014-10-28 18:21:24 +01:00
unsigned long state ;
2014-11-05 20:51:17 +01:00
char name [ IFNAMSIZ ] ;
2012-05-15 20:50:24 +00:00
2014-05-16 17:46:40 +02:00
/* protects sec from concurrent access by netlink. access by
* encrypt / decrypt / header_create safe without additional protection .
*/
struct mutex sec_mtx ;
struct mac802154_llsec sec ;
2012-05-15 20:50:24 +00:00
} ;
2014-11-12 03:36:51 +01:00
/* utility functions/constants */
extern const void * const mac802154_wpan_phy_privid ; /* for wpan_phy privid */
2014-10-25 17:16:39 +02:00
static inline struct ieee802154_local *
hw_to_local ( struct ieee802154_hw * hw )
{
return container_of ( hw , struct ieee802154_local , hw ) ;
}
2014-10-25 17:16:40 +02:00
static inline struct ieee802154_sub_if_data *
IEEE802154_DEV_TO_SUB_IF ( const struct net_device * dev )
{
return netdev_priv ( dev ) ;
}
2014-11-17 08:20:53 +01:00
static inline struct ieee802154_sub_if_data *
IEEE802154_WPAN_DEV_TO_SUB_IF ( struct wpan_dev * wpan_dev )
{
return container_of ( wpan_dev , struct ieee802154_sub_if_data , wpan_dev ) ;
}
2014-10-28 18:21:24 +01:00
static inline bool
ieee802154_sdata_running ( struct ieee802154_sub_if_data * sdata )
{
return test_bit ( SDATA_STATE_RUNNING , & sdata - > state ) ;
}
2012-06-25 23:24:48 +00:00
extern struct ieee802154_mlme_ops mac802154_mlme_wpan ;
2012-05-15 20:50:25 +00:00
2015-07-07 10:50:43 +05:30
void ieee802154_rx ( struct ieee802154_local * local , struct sk_buff * skb ) ;
2022-05-19 17:05:06 +02:00
void ieee802154_xmit_sync_worker ( struct work_struct * work ) ;
2022-05-19 17:05:13 +02:00
int ieee802154_sync_and_hold_queue ( struct ieee802154_local * local ) ;
2022-05-19 17:05:14 +02:00
int ieee802154_mlme_op_pre ( struct ieee802154_local * local ) ;
2022-06-17 21:29:14 +02:00
int ieee802154_mlme_tx ( struct ieee802154_local * local ,
struct ieee802154_sub_if_data * sdata ,
struct sk_buff * skb ) ;
2022-05-19 17:05:14 +02:00
void ieee802154_mlme_op_post ( struct ieee802154_local * local ) ;
2022-06-17 21:29:14 +02:00
int ieee802154_mlme_tx_one ( struct ieee802154_local * local ,
struct ieee802154_sub_if_data * sdata ,
struct sk_buff * skb ) ;
2014-10-26 09:37:13 +01:00
netdev_tx_t
ieee802154_monitor_start_xmit ( struct sk_buff * skb , struct net_device * dev ) ;
netdev_tx_t
ieee802154_subif_start_xmit ( struct sk_buff * skb , struct net_device * dev ) ;
2014-11-12 19:51:56 +01:00
enum hrtimer_restart ieee802154_xmit_ifs_timer ( struct hrtimer * timer ) ;
2012-05-15 20:50:22 +00:00
2022-05-19 17:05:10 +02:00
/**
* ieee802154_hold_queue - hold ieee802154 queue
* @ local : main mac object
*
* Hold a queue by incrementing an atomic counter and requesting the netif
* queues to be stopped . The queues cannot be woken up while the counter has not
* been reset with as any ieee802154_release_queue ( ) calls as needed .
*/
void ieee802154_hold_queue ( struct ieee802154_local * local ) ;
/**
* ieee802154_release_queue - release ieee802154 queue
* @ local : main mac object
*
* Release a queue which is held by decrementing an atomic counter and wake it
* up only if the counter reaches 0.
*/
void ieee802154_release_queue ( struct ieee802154_local * local ) ;
2022-05-19 17:05:12 +02:00
/**
* ieee802154_disable_queue - disable ieee802154 queue
* @ local : main mac object
*
* When trying to sync the Tx queue , we cannot just stop the queue
* ( which is basically a bit being set without proper lock handling )
* because it would be racy . We actually need to call netif_tx_disable ( )
* instead , which is done by this helper . Restarting the queue can
* however still be done with a regular wake call .
*/
void ieee802154_disable_queue ( struct ieee802154_local * local ) ;
2012-05-15 20:50:26 +00:00
/* MIB callbacks */
2012-06-25 23:24:51 +00:00
void mac802154_dev_set_page_channel ( struct net_device * dev , u8 page , u8 chan ) ;
2012-05-15 20:50:26 +00:00
2014-05-16 17:46:42 +02:00
int mac802154_get_params ( struct net_device * dev ,
struct ieee802154_llsec_params * params ) ;
int mac802154_set_params ( struct net_device * dev ,
const struct ieee802154_llsec_params * params ,
int changed ) ;
int mac802154_add_key ( struct net_device * dev ,
const struct ieee802154_llsec_key_id * id ,
const struct ieee802154_llsec_key * key ) ;
int mac802154_del_key ( struct net_device * dev ,
const struct ieee802154_llsec_key_id * id ) ;
int mac802154_add_dev ( struct net_device * dev ,
const struct ieee802154_llsec_device * llsec_dev ) ;
int mac802154_del_dev ( struct net_device * dev , __le64 dev_addr ) ;
int mac802154_add_devkey ( struct net_device * dev ,
__le64 device_addr ,
const struct ieee802154_llsec_device_key * key ) ;
int mac802154_del_devkey ( struct net_device * dev ,
__le64 device_addr ,
const struct ieee802154_llsec_device_key * key ) ;
int mac802154_add_seclevel ( struct net_device * dev ,
const struct ieee802154_llsec_seclevel * sl ) ;
int mac802154_del_seclevel ( struct net_device * dev ,
const struct ieee802154_llsec_seclevel * sl ) ;
void mac802154_lock_table ( struct net_device * dev ) ;
void mac802154_get_table ( struct net_device * dev ,
struct ieee802154_llsec_table * * t ) ;
void mac802154_unlock_table ( struct net_device * dev ) ;
2015-06-21 16:45:20 +02:00
int mac802154_wpan_update_llsec ( struct net_device * dev ) ;
2014-11-12 03:36:53 +01:00
/* interface handling */
int ieee802154_iface_init ( void ) ;
void ieee802154_iface_exit ( void ) ;
2014-11-05 20:51:14 +01:00
void ieee802154_if_remove ( struct ieee802154_sub_if_data * sdata ) ;
2014-11-05 20:51:15 +01:00
struct net_device *
ieee802154_if_add ( struct ieee802154_local * local , const char * name ,
2015-04-30 17:44:57 +02:00
unsigned char name_assign_type , enum nl802154_iftype type ,
__le64 extended_addr ) ;
2014-11-12 03:36:48 +01:00
void ieee802154_remove_interfaces ( struct ieee802154_local * local ) ;
2015-06-24 11:36:34 +02:00
void ieee802154_stop_device ( struct ieee802154_local * local ) ;
2014-11-02 04:18:38 +01:00
2014-10-25 09:41:00 +02:00
# endif /* __IEEE802154_I_H */