116878352SSascha Wildner /*-
216878352SSascha Wildner  * Copyright (c) 2010 Bernhard Schmidt <bschmidt@FreeBSD.org>
316878352SSascha Wildner  * All rights reserved.
4b9334f94SSepherosa Ziehau  *
5b9334f94SSepherosa Ziehau  * Redistribution and use in source and binary forms, with or without
6b9334f94SSepherosa Ziehau  * modification, are permitted provided that the following conditions
7b9334f94SSepherosa Ziehau  * are met:
8b9334f94SSepherosa Ziehau  * 1. Redistributions of source code must retain the above copyright
9b9334f94SSepherosa Ziehau  *    notice, this list of conditions and the following disclaimer.
10b9334f94SSepherosa Ziehau  * 2. Redistributions in binary form must reproduce the above copyright
1116878352SSascha Wildner  *    notice, this list of conditions and the following disclaimer in the
1216878352SSascha Wildner  *    documentation and/or other materials provided with the distribution.
13b9334f94SSepherosa Ziehau  *
1416878352SSascha Wildner  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
1516878352SSascha Wildner  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
1616878352SSascha Wildner  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
1716878352SSascha Wildner  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
1816878352SSascha Wildner  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
1916878352SSascha Wildner  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
2016878352SSascha Wildner  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
2116878352SSascha Wildner  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
2216878352SSascha Wildner  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
2316878352SSascha Wildner  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24b9334f94SSepherosa Ziehau  */
25b9334f94SSepherosa Ziehau 
26085ff963SMatthew Dillon #include <sys/cdefs.h>
27085ff963SMatthew Dillon __FBSDID("$FreeBSD$");
28085ff963SMatthew Dillon 
2916878352SSascha Wildner #include "opt_wlan.h"
3016878352SSascha Wildner 
31b9334f94SSepherosa Ziehau #include <sys/param.h>
3216878352SSascha Wildner #include <sys/systm.h>
33b9334f94SSepherosa Ziehau #include <sys/kernel.h>
3416878352SSascha Wildner #include <sys/malloc.h>
3516878352SSascha Wildner #include <sys/module.h>
3616878352SSascha Wildner #include <sys/socket.h>
3716878352SSascha Wildner #include <sys/sysctl.h>
38b9334f94SSepherosa Ziehau 
39b9334f94SSepherosa Ziehau #include <net/if.h>
40*bff82488SAaron LI #include <net/if_var.h>
41b9334f94SSepherosa Ziehau #include <net/if_media.h>
4216878352SSascha Wildner #include <net/ethernet.h>
4316878352SSascha Wildner 
44b9334f94SSepherosa Ziehau #include <netproto/802_11/ieee80211_var.h>
4516878352SSascha Wildner #include <netproto/802_11/ieee80211_ratectl.h>
46b9334f94SSepherosa Ziehau 
4716878352SSascha Wildner static void
none_init(struct ieee80211vap * vap)4816878352SSascha Wildner none_init(struct ieee80211vap *vap)
4916878352SSascha Wildner {
5016878352SSascha Wildner }
51b9334f94SSepherosa Ziehau 
5216878352SSascha Wildner static void
none_deinit(struct ieee80211vap * vap)5316878352SSascha Wildner none_deinit(struct ieee80211vap *vap)
5416878352SSascha Wildner {
554f655ef5SMatthew Dillon 	IEEE80211_FREE(vap->iv_rs, M_80211_RATECTL);
5616878352SSascha Wildner }
5716878352SSascha Wildner 
5816878352SSascha Wildner static void
none_node_init(struct ieee80211_node * ni)5916878352SSascha Wildner none_node_init(struct ieee80211_node *ni)
6016878352SSascha Wildner {
6116878352SSascha Wildner 	ni->ni_txrate = ni->ni_rates.rs_rates[0] & IEEE80211_RATE_VAL;
6216878352SSascha Wildner }
6316878352SSascha Wildner 
6416878352SSascha Wildner static void
none_node_deinit(struct ieee80211_node * ni)6516878352SSascha Wildner none_node_deinit(struct ieee80211_node *ni)
6616878352SSascha Wildner {
6716878352SSascha Wildner }
6816878352SSascha Wildner 
6916878352SSascha Wildner static int
none_rate(struct ieee80211_node * ni,void * arg __unused,uint32_t iarg __unused)7016878352SSascha Wildner none_rate(struct ieee80211_node *ni, void *arg __unused, uint32_t iarg __unused)
7116878352SSascha Wildner {
7216878352SSascha Wildner 	int rix = 0;
7316878352SSascha Wildner 
7416878352SSascha Wildner 	ni->ni_txrate = ni->ni_rates.rs_rates[rix] & IEEE80211_RATE_VAL;
7516878352SSascha Wildner 	return rix;
7616878352SSascha Wildner }
7716878352SSascha Wildner 
7816878352SSascha Wildner static void
none_tx_complete(const struct ieee80211vap * vap,const struct ieee80211_node * ni,int ok,void * arg1,void * arg2 __unused)7916878352SSascha Wildner none_tx_complete(const struct ieee80211vap *vap,
8016878352SSascha Wildner     const struct ieee80211_node *ni, int ok,
8116878352SSascha Wildner     void *arg1, void *arg2 __unused)
8216878352SSascha Wildner {
8316878352SSascha Wildner }
8416878352SSascha Wildner 
8516878352SSascha Wildner static void
none_tx_update(const struct ieee80211vap * vap,const struct ieee80211_node * ni,void * arg1,void * arg2,void * arg3)8616878352SSascha Wildner none_tx_update(const struct ieee80211vap *vap, const struct ieee80211_node *ni,
8716878352SSascha Wildner     void *arg1, void *arg2, void *arg3)
8816878352SSascha Wildner {
8916878352SSascha Wildner }
9016878352SSascha Wildner 
9116878352SSascha Wildner static void
none_setinterval(const struct ieee80211vap * vap,int msecs)9216878352SSascha Wildner none_setinterval(const struct ieee80211vap *vap, int msecs)
9316878352SSascha Wildner {
9416878352SSascha Wildner }
9516878352SSascha Wildner 
9616878352SSascha Wildner /* number of references from net80211 layer */
9716878352SSascha Wildner static	int nrefs = 0;
9816878352SSascha Wildner 
9916878352SSascha Wildner static const struct ieee80211_ratectl none = {
10016878352SSascha Wildner 	.ir_name	= "none",
10116878352SSascha Wildner 	.ir_attach	= NULL,
10216878352SSascha Wildner 	.ir_detach	= NULL,
10316878352SSascha Wildner 	.ir_init	= none_init,
10416878352SSascha Wildner 	.ir_deinit	= none_deinit,
10516878352SSascha Wildner 	.ir_node_init	= none_node_init,
10616878352SSascha Wildner 	.ir_node_deinit	= none_node_deinit,
10716878352SSascha Wildner 	.ir_rate	= none_rate,
10816878352SSascha Wildner 	.ir_tx_complete	= none_tx_complete,
10916878352SSascha Wildner 	.ir_tx_update	= none_tx_update,
11016878352SSascha Wildner 	.ir_setinterval	= none_setinterval,
111b9334f94SSepherosa Ziehau };
11216878352SSascha Wildner IEEE80211_RATECTL_MODULE(ratectl_none, 1);
11316878352SSascha Wildner IEEE80211_RATECTL_ALG(none, IEEE80211_RATECTL_NONE, none);
114