wpan-phy.h 2.6 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25
/*
 * Copyright (C) 2007, 2008, 2009 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.
 *
 * You should have received a copy of the GNU General Public License along
 * with this program; if not, write to the Free Software Foundation, Inc.,
 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
 *
 * Written by:
 * Dmitry Eremin-Solenikov <dbaryshkov@gmail.com>
 */

#ifndef WPAN_PHY_H
#define WPAN_PHY_H

#include <linux/netdevice.h>
#include <linux/mutex.h>
26
#include <linux/bug.h>
27

28 29 30 31 32 33 34 35
/* According to the IEEE 802.15.4 stadard the upper most significant bits of
 * the 32-bit channel bitmaps shall be used as an integer value to specify 32
 * possible channel pages. The lower 27 bits of the channel bit map shall be
 * used as a bit mask to specify channel numbers within a channel page.
 */
#define WPAN_NUM_CHANNELS	27
#define WPAN_NUM_PAGES		32

36 37 38 39
struct wpan_phy {
	struct mutex pib_lock;

	/*
40
	 * This is a PIB according to 802.15.4-2011.
41 42 43 44 45
	 * We do not provide timing-related variables, as they
	 * aren't used outside of driver
	 */
	u8 current_channel;
	u8 current_page;
46
	u32 channels_supported[32];
47
	s8 transmit_power;
48 49 50 51 52
	u8 cca_mode;

	struct device dev;
	int idx;

53
	struct net_device *(*add_iface)(struct wpan_phy *phy,
54
					const char *name, int type);
55 56
	void (*del_iface)(struct wpan_phy *phy, struct net_device *dev);

57 58
	int (*set_txpower)(struct wpan_phy *phy, int db);

59 60 61
	char priv[0] __attribute__((__aligned__(NETDEV_ALIGN)));
};

62 63
#define to_phy(_dev)	container_of(_dev, struct wpan_phy, dev)

64
struct wpan_phy *wpan_phy_alloc(size_t priv_size);
65 66 67 68 69
static inline void wpan_phy_set_dev(struct wpan_phy *phy, struct device *dev)
{
	phy->dev.parent = dev;
}
int wpan_phy_register(struct wpan_phy *phy);
70 71
void wpan_phy_unregister(struct wpan_phy *phy);
void wpan_phy_free(struct wpan_phy *phy);
72 73
/* Same semantics as for class_for_each_device */
int wpan_phy_for_each(int (*fn)(struct wpan_phy *phy, void *data), void *data);
74 75 76 77 78 79 80 81

static inline void *wpan_phy_priv(struct wpan_phy *phy)
{
	BUG_ON(!phy);
	return &phy->priv;
}

struct wpan_phy *wpan_phy_find(const char *str);
82 83 84 85 86 87

static inline void wpan_phy_put(struct wpan_phy *phy)
{
	put_device(&phy->dev);
}

88 89 90 91 92
static inline const char *wpan_phy_name(struct wpan_phy *phy)
{
	return dev_name(&phy->dev);
}
#endif