summaryrefslogtreecommitdiff
path: root/sys/net80211
diff options
context:
space:
mode:
Diffstat (limited to 'sys/net80211')
-rw-r--r--sys/net80211/ieee80211.c16
-rw-r--r--sys/net80211/ieee80211_crypto.c10
-rw-r--r--sys/net80211/ieee80211_input.c25
-rw-r--r--sys/net80211/ieee80211_node.c51
-rw-r--r--sys/net80211/ieee80211_output.c10
-rw-r--r--sys/net80211/ieee80211_proto.c6
6 files changed, 62 insertions, 56 deletions
diff --git a/sys/net80211/ieee80211.c b/sys/net80211/ieee80211.c
index a497abfeaa5..4a10b850812 100644
--- a/sys/net80211/ieee80211.c
+++ b/sys/net80211/ieee80211.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ieee80211.c,v 1.21 2007/06/06 19:31:07 damien Exp $ */
+/* $OpenBSD: ieee80211.c,v 1.22 2007/06/16 11:56:20 damien Exp $ */
/* $NetBSD: ieee80211.c,v 1.19 2004/06/06 05:45:29 dyoung Exp $ */
/*-
@@ -72,7 +72,8 @@ int ieee80211_cache_size = IEEE80211_CACHE_SIZE;
struct ieee80211com_head ieee80211com_head =
LIST_HEAD_INITIALIZER(ieee80211com_head);
-static void ieee80211_setbasicrates(struct ieee80211com *);
+void ieee80211_setbasicrates(struct ieee80211com *);
+int ieee80211_findrate(struct ieee80211com *, enum ieee80211_phymode, int);
void
ieee80211_ifattach(struct ifnet *ifp)
@@ -349,8 +350,9 @@ ieee80211_media_init(struct ifnet *ifp,
#undef ADD
}
-static int
-findrate(struct ieee80211com *ic, enum ieee80211_phymode mode, int rate)
+int
+ieee80211_findrate(struct ieee80211com *ic, enum ieee80211_phymode mode,
+ int rate)
{
#define IEEERATE(_ic,_m,_i) \
((_ic)->ic_sup_rates[_m].rs_rates[_i] & IEEE80211_RATE_VAL)
@@ -434,7 +436,7 @@ ieee80211_media_change(struct ifnet *ifp)
j < IEEE80211_MODE_MAX; j++) {
if ((ic->ic_modecaps & (1<<j)) == 0)
continue;
- i = findrate(ic, j, newrate);
+ i = ieee80211_findrate(ic, j, newrate);
if (i != -1) {
/* lock mode too */
newphymode = j;
@@ -442,7 +444,7 @@ ieee80211_media_change(struct ifnet *ifp)
}
}
} else {
- i = findrate(ic, newphymode, newrate);
+ i = ieee80211_findrate(ic, newphymode, newrate);
}
if (i == -1) /* mode/rate mismatch */
return EINVAL;
@@ -606,7 +608,7 @@ struct ieee80211_rateset ieee80211_std_rateset_11g =
* 11b rates. There's also a pseudo 11a-mode used to mark only
* the basic OFDM rates.
*/
-static void
+void
ieee80211_setbasicrates(struct ieee80211com *ic)
{
static const struct ieee80211_rateset basic[] = {
diff --git a/sys/net80211/ieee80211_crypto.c b/sys/net80211/ieee80211_crypto.c
index f1d520e2ba5..fd7eb8a931d 100644
--- a/sys/net80211/ieee80211_crypto.c
+++ b/sys/net80211/ieee80211_crypto.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ieee80211_crypto.c,v 1.10 2007/06/06 19:31:07 damien Exp $ */
+/* $OpenBSD: ieee80211_crypto.c,v 1.11 2007/06/16 11:56:20 damien Exp $ */
/* $NetBSD: ieee80211_crypto.c,v 1.5 2003/12/14 09:56:53 dyoung Exp $ */
/*-
@@ -66,8 +66,8 @@
#define arc4_setkey(_c,_k,_l) rc4_keysetup(_c,_k,_l)
#define arc4_encrypt(_c,_d,_s,_l) rc4_crypt(_c,_s,_d,_l)
-static void ieee80211_crc_init(void);
-static u_int32_t ieee80211_crc_update(u_int32_t crc, u_int8_t *buf, int len);
+void ieee80211_crc_init(void);
+u_int32_t ieee80211_crc_update(u_int32_t crc, u_int8_t *buf, int len);
void
ieee80211_crypto_attach(struct ifnet *ifp)
@@ -293,7 +293,7 @@ ieee80211_wep_crypt(struct ifnet *ifp, struct mbuf *m0, int txflag)
static u_int32_t ieee80211_crc_table[256];
/* Make the table for a fast CRC. */
-static void
+void
ieee80211_crc_init(void)
{
u_int32_t c;
@@ -317,7 +317,7 @@ ieee80211_crc_init(void)
* is the 1's complement of the final running CRC
*/
-static u_int32_t
+u_int32_t
ieee80211_crc_update(u_int32_t crc, u_int8_t *buf, int len)
{
u_int8_t *endbuf;
diff --git a/sys/net80211/ieee80211_input.c b/sys/net80211/ieee80211_input.c
index de9398f2eb4..5f3951de262 100644
--- a/sys/net80211/ieee80211_input.c
+++ b/sys/net80211/ieee80211_input.c
@@ -1,5 +1,5 @@
/* $NetBSD: ieee80211_input.c,v 1.24 2004/05/31 11:12:24 dyoung Exp $ */
-/* $OpenBSD: ieee80211_input.c,v 1.23 2007/06/06 19:31:07 damien Exp $ */
+/* $OpenBSD: ieee80211_input.c,v 1.24 2007/06/16 11:56:20 damien Exp $ */
/*-
* Copyright (c) 2001 Atsushi Onoe
* Copyright (c) 2002, 2003 Sam Leffler, Errno Consulting
@@ -67,9 +67,14 @@ const struct timeval ieee80211_merge_print_intvl = {
.tv_usec = 0
};
-static void ieee80211_recv_pspoll(struct ieee80211com *,
- struct mbuf *, int, u_int32_t);
-static int ieee80211_do_slow_print(struct ieee80211com *, int *);
+
+int ieee80211_setup_rates(struct ieee80211com *, struct ieee80211_node *,
+ u_int8_t *, u_int8_t *, int);
+void ieee80211_auth_open(struct ieee80211com *, struct ieee80211_frame *,
+ struct ieee80211_node *, int, u_int32_t, u_int16_t, u_int16_t);
+void ieee80211_recv_pspoll(struct ieee80211com *, struct mbuf *, int,
+ u_int32_t);
+int ieee80211_do_slow_print(struct ieee80211com *, int *);
/*
* Process a received frame. The node associated with the sender
@@ -557,7 +562,7 @@ ieee80211_decap(struct ifnet *ifp, struct mbuf *m)
/*
* Install received rate set information in the node's state block.
*/
-static int
+int
ieee80211_setup_rates(struct ieee80211com *ic, struct ieee80211_node *ni,
u_int8_t *rates, u_int8_t *xrates, int flags)
{
@@ -618,7 +623,7 @@ ieee80211_setup_rates(struct ieee80211com *ic, struct ieee80211_node *ni,
} while (0)
#ifdef IEEE80211_DEBUG
-static void
+void
ieee80211_ssid_mismatch(struct ieee80211com *ic, const char *tag,
u_int8_t mac[IEEE80211_ADDR_LEN], u_int8_t *ssid)
{
@@ -649,7 +654,7 @@ ieee80211_ssid_mismatch(struct ieee80211com *ic, const char *tag,
} while (0)
#endif /* !IEEE80211_DEBUG */
-static void
+void
ieee80211_auth_open(struct ieee80211com *ic, struct ieee80211_frame *wh,
struct ieee80211_node *ni, int rssi, u_int32_t rstamp, u_int16_t seq,
u_int16_t status)
@@ -735,7 +740,7 @@ ieee80211_auth_open(struct ieee80211com *ic, struct ieee80211_frame *wh,
#if 0
/* TBD send appropriate responses on error? */
-static void
+void
ieee80211_auth_shared(struct ieee80211com *ic, struct ieee80211_frame *wh,
u_int8_t *frm, u_int8_t *efrm, struct ieee80211_node *ni, int rssi,
u_int32_t rstamp, u_int16_t seq, u_int16_t status)
@@ -1553,7 +1558,7 @@ ieee80211_recv_mgmt(struct ieee80211com *ic, struct mbuf *m0,
#undef IEEE80211_VERIFY_ELEMENT
#undef IEEE80211_VERIFY_SSID
-static void
+void
ieee80211_recv_pspoll(struct ieee80211com *ic, struct mbuf *m0, int rssi,
u_int32_t rstamp)
{
@@ -1623,7 +1628,7 @@ ieee80211_recv_pspoll(struct ieee80211com *ic, struct mbuf *m0, int rssi,
(*ifp->if_start)(ifp);
}
-static int
+int
ieee80211_do_slow_print(struct ieee80211com *ic, int *did_print)
{
if ((ic->ic_if.if_flags & IFF_LINK0) == 0)
diff --git a/sys/net80211/ieee80211_node.c b/sys/net80211/ieee80211_node.c
index 21398865fe6..48f13002dae 100644
--- a/sys/net80211/ieee80211_node.c
+++ b/sys/net80211/ieee80211_node.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ieee80211_node.c,v 1.21 2007/06/07 20:24:42 damien Exp $ */
+/* $OpenBSD: ieee80211_node.c,v 1.22 2007/06/16 11:56:20 damien Exp $ */
/* $NetBSD: ieee80211_node.c,v 1.14 2004/05/09 09:18:47 dyoung Exp $ */
/*-
@@ -68,24 +68,19 @@
#include <dev/rndvar.h>
-static struct ieee80211_node *ieee80211_node_alloc(struct ieee80211com *);
-static void ieee80211_node_free(struct ieee80211com *, struct ieee80211_node *);
-static void ieee80211_node_copy(struct ieee80211com *,
- struct ieee80211_node *, const struct ieee80211_node *);
-static u_int8_t ieee80211_node_getrssi(struct ieee80211com *,
- struct ieee80211_node *);
-static void ieee80211_setup_node(struct ieee80211com *ic,
- struct ieee80211_node *ni, u_int8_t *macaddr);
-static void ieee80211_free_node(struct ieee80211com *,
- struct ieee80211_node *);
-static struct ieee80211_node *
- ieee80211_alloc_node_helper(struct ieee80211com *);
-static void ieee80211_node_cleanup(struct ieee80211com *,
- struct ieee80211_node *);
-static void ieee80211_node_join_11g(struct ieee80211com *,
- struct ieee80211_node *);
-static void ieee80211_node_leave_11g(struct ieee80211com *,
+struct ieee80211_node *ieee80211_node_alloc(struct ieee80211com *);
+void ieee80211_node_free(struct ieee80211com *, struct ieee80211_node *);
+void ieee80211_node_copy(struct ieee80211com *, struct ieee80211_node *,
+ const struct ieee80211_node *);
+u_int8_t ieee80211_node_getrssi(struct ieee80211com *,
struct ieee80211_node *);
+void ieee80211_setup_node(struct ieee80211com *, struct ieee80211_node *,
+ u_int8_t *);
+void ieee80211_free_node(struct ieee80211com *, struct ieee80211_node *);
+struct ieee80211_node *ieee80211_alloc_node_helper(struct ieee80211com *);
+void ieee80211_node_cleanup(struct ieee80211com *, struct ieee80211_node *);
+void ieee80211_node_join_11g(struct ieee80211com *, struct ieee80211_node *);
+void ieee80211_node_leave_11g(struct ieee80211com *, struct ieee80211_node *);
#define M_80211_NODE M_DEVBUF
@@ -117,7 +112,7 @@ ieee80211_node_attach(struct ifnet *ifp)
memset(ic->ic_aid_bitmap, 0, size);
}
-static struct ieee80211_node *
+struct ieee80211_node *
ieee80211_alloc_node_helper(struct ieee80211com *ic)
{
struct ieee80211_node *ni;
@@ -511,7 +506,7 @@ ieee80211_get_rate(struct ieee80211com *ic)
return rate & IEEE80211_RATE_VAL;
}
-static struct ieee80211_node *
+struct ieee80211_node *
ieee80211_node_alloc(struct ieee80211com *ic)
{
struct ieee80211_node *ni;
@@ -522,7 +517,7 @@ ieee80211_node_alloc(struct ieee80211com *ic)
return ni;
}
-static void
+void
ieee80211_node_cleanup(struct ieee80211com *ic, struct ieee80211_node *ni)
{
if (ni->ni_challenge != NULL) {
@@ -531,14 +526,14 @@ ieee80211_node_cleanup(struct ieee80211com *ic, struct ieee80211_node *ni)
}
}
-static void
+void
ieee80211_node_free(struct ieee80211com *ic, struct ieee80211_node *ni)
{
ieee80211_node_cleanup(ic, ni);
FREE(ni, M_80211_NODE);
}
-static void
+void
ieee80211_node_copy(struct ieee80211com *ic,
struct ieee80211_node *dst, const struct ieee80211_node *src)
{
@@ -547,13 +542,13 @@ ieee80211_node_copy(struct ieee80211com *ic,
dst->ni_challenge = NULL;
}
-static u_int8_t
+u_int8_t
ieee80211_node_getrssi(struct ieee80211com *ic, struct ieee80211_node *ni)
{
return ni->ni_rssi;
}
-static void
+void
ieee80211_setup_node(struct ieee80211com *ic,
struct ieee80211_node *ni, u_int8_t *macaddr)
{
@@ -809,7 +804,7 @@ ieee80211_find_node_for_beacon(struct ieee80211com *ic, u_int8_t *macaddr,
return (keep);
}
-static void
+void
ieee80211_free_node(struct ieee80211com *ic, struct ieee80211_node *ni)
{
if (ni == ic->ic_bss)
@@ -944,7 +939,7 @@ ieee80211_iserp_sta(struct ieee80211_node *ni)
/*
* Handle a station joining an 11g network.
*/
-static void
+void
ieee80211_node_join_11g(struct ieee80211com *ic, struct ieee80211_node *ni)
{
if (!(ni->ni_capinfo & IEEE80211_CAPINFO_SHORT_SLOTTIME)) {
@@ -1043,7 +1038,7 @@ ieee80211_node_join(struct ieee80211com *ic, struct ieee80211_node *ni,
/*
* Handle a station leaving an 11g network.
*/
-static void
+void
ieee80211_node_leave_11g(struct ieee80211com *ic, struct ieee80211_node *ni)
{
if (!(ni->ni_capinfo & IEEE80211_CAPINFO_SHORT_SLOTTIME)) {
diff --git a/sys/net80211/ieee80211_output.c b/sys/net80211/ieee80211_output.c
index d291e878cc7..0037623712c 100644
--- a/sys/net80211/ieee80211_output.c
+++ b/sys/net80211/ieee80211_output.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ieee80211_output.c,v 1.26 2007/06/11 19:35:24 damien Exp $ */
+/* $OpenBSD: ieee80211_output.c,v 1.27 2007/06/16 11:56:20 damien Exp $ */
/* $NetBSD: ieee80211_output.c,v 1.13 2004/05/31 11:02:55 dyoung Exp $ */
/*-
@@ -56,6 +56,10 @@
#include <net80211/ieee80211_var.h>
+int ieee80211_mgmt_output(struct ifnet *, struct ieee80211_node *,
+ struct mbuf *, int);
+struct mbuf *ieee80211_getmbuf(int, int, u_int);
+
/*
* IEEE 802.11 output routine. Normally this will directly call the
* Ethernet output routine because 802.11 encapsulation is called
@@ -125,7 +129,7 @@ ieee80211_output(struct ifnet *ifp, struct mbuf *m, struct sockaddr *dst,
* dispatched to the driver, then it is responsible for freeing the
* reference (and potentially free'ing up any associated storage).
*/
-static int
+int
ieee80211_mgmt_output(struct ifnet *ifp, struct ieee80211_node *ni,
struct mbuf *m, int type)
{
@@ -514,7 +518,7 @@ ieee80211_add_erp(u_int8_t *frm, struct ieee80211com *ic)
return frm;
}
-static struct mbuf *
+struct mbuf *
ieee80211_getmbuf(int flags, int type, u_int pktlen)
{
struct mbuf *m;
diff --git a/sys/net80211/ieee80211_proto.c b/sys/net80211/ieee80211_proto.c
index 684754352f3..27069916f05 100644
--- a/sys/net80211/ieee80211_proto.c
+++ b/sys/net80211/ieee80211_proto.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ieee80211_proto.c,v 1.15 2007/06/06 19:31:07 damien Exp $ */
+/* $OpenBSD: ieee80211_proto.c,v 1.16 2007/06/16 11:56:20 damien Exp $ */
/* $NetBSD: ieee80211_proto.c,v 1.8 2004/04/30 23:58:20 dyoung Exp $ */
/*-
@@ -87,7 +87,7 @@ const char *ieee80211_phymode_name[] = {
"turbo", /* IEEE80211_MODE_TURBO */
};
-static int ieee80211_newstate(struct ieee80211com *, enum ieee80211_state, int);
+int ieee80211_newstate(struct ieee80211com *, enum ieee80211_state, int);
void
ieee80211_proto_attach(struct ifnet *ifp)
@@ -353,7 +353,7 @@ ieee80211_set_shortslottime(struct ieee80211com *ic, int on)
ic->ic_updateslot(ic);
}
-static int
+int
ieee80211_newstate(struct ieee80211com *ic, enum ieee80211_state nstate,
int mgt)
{