ieee802154_i.h 5.2 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
/*
 * Copyright (C) 2007-2012 Siemens AG
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2
 * as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * 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>
 */
19 20
#ifndef __IEEE802154_I_H
#define __IEEE802154_I_H
21

22
#include <linux/mutex.h>
23
#include <net/cfg802154.h>
24
#include <net/mac802154.h>
25 26
#include <net/ieee802154_netdev.h>

27 28
#include "llsec.h"

29
/* mac802154 device private data */
30
struct ieee802154_local {
31
	struct ieee802154_hw hw;
32
	const struct ieee802154_ops *ops;
33 34 35 36 37 38 39 40 41 42 43 44 45

	/* 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.
	 */
46 47
	struct list_head	interfaces;
	struct mutex		iflist_mtx;
48 49 50 51

	/* This one is used for scanning and other jobs not to be interfered
	 * with serial driver.
	 */
52
	struct workqueue_struct	*workqueue;
53

54
	bool started;
55 56 57

	struct tasklet_struct tasklet;
	struct sk_buff_head skb_queue;
58 59
};

60 61 62 63
enum {
	IEEE802154_RX_MSG        = 1,
};

64 65 66 67
enum ieee802154_sdata_state_bits {
	SDATA_STATE_RUNNING,
};

68 69 70 71 72 73
/* 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.
 */
74
struct ieee802154_sub_if_data {
75 76
	struct list_head list; /* the ieee802154_priv->slaves list */

77 78
	struct wpan_dev wpan_dev;

79
	struct ieee802154_local *local;
80 81
	struct net_device *dev;

82
	unsigned long state;
83
	char name[IFNAMSIZ];
84 85 86

	spinlock_t mib_lock;

87 88
	struct ieee802154_mac_params mac_params;

89 90 91 92 93 94
	/* 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;
95 96
	/* must be last, dynamically sized area in this! */
	struct ieee802154_vif vif;
97 98
};

99
#define MAC802154_CHAN_NONE		0xff /* No channel is assigned */
100

101 102 103 104 105 106
static inline struct ieee802154_local *
hw_to_local(struct ieee802154_hw *hw)
{
	return container_of(hw, struct ieee802154_local, hw);
}

107 108 109 110 111 112
static inline struct ieee802154_sub_if_data *
IEEE802154_DEV_TO_SUB_IF(const struct net_device *dev)
{
	return netdev_priv(dev);
}

113 114 115 116 117 118
static inline bool
ieee802154_sdata_running(struct ieee802154_sub_if_data *sdata)
{
	return test_bit(SDATA_STATE_RUNNING, &sdata->state);
}

119
extern struct ieee802154_reduced_mlme_ops mac802154_mlme_reduced;
120
extern struct ieee802154_mlme_ops mac802154_mlme_wpan;
121

122
void mac802154_monitor_setup(struct net_device *dev);
123 124
netdev_tx_t
ieee802154_monitor_start_xmit(struct sk_buff *skb, struct net_device *dev);
125

126
void mac802154_wpan_setup(struct net_device *dev);
127 128
netdev_tx_t
ieee802154_subif_start_xmit(struct sk_buff *skb, struct net_device *dev);
129

130
/* MIB callbacks */
131 132 133 134
void mac802154_dev_set_short_addr(struct net_device *dev, __le16 val);
__le16 mac802154_dev_get_short_addr(const struct net_device *dev);
__le16 mac802154_dev_get_pan_id(const struct net_device *dev);
void mac802154_dev_set_pan_id(struct net_device *dev, __le16 val);
135
void mac802154_dev_set_page_channel(struct net_device *dev, u8 page, u8 chan);
136
u8 mac802154_dev_get_dsn(const struct net_device *dev);
137

138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170
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);

171 172
struct net_device *
mac802154_add_iface(struct wpan_phy *phy, const char *name, int type);
173
void ieee802154_if_remove(struct ieee802154_sub_if_data *sdata);
174 175 176
struct net_device *
ieee802154_if_add(struct ieee802154_local *local, const char *name,
		  struct wpan_dev **new_wpan_dev, int type);
177

178
#endif /* __IEEE802154_I_H */