diff options
author | Johannes Berg <johannes@sipsolutions.net> | 2008-01-02 09:17:03 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2008-01-28 18:01:02 -0500 |
commit | 4b475898ec9dc6e62cebcb8fc0b3495c986a4590 (patch) | |
tree | 8409a6865f3d83965228fd8f6fae3b05e1e106ed /net/mac80211/rc80211_pid_algo.c | |
parent | 688b88a4886834d7e3457711cd4feef6611d3232 (diff) |
mac80211: better rate control algorithm selection
This patch changes mac80211's Kconfig/Makefile to:
* select between the PID and the SIMPLE rate control
algorithm as default
* always allow tri-state for the rate control algorithms,
building those that are selected 'y' into the mac80211
module (if that is a module, otherwise all into the kernel)
* force the default rate control algorithm to be built into
mac80211
It also makes both rate control algorithms proper modules again
with MODULE_LICENSE etc.
Only if EMBEDDED is the user allowed to select "NONE" as default
which will cause no algorithm to be selected, this will work
only when the driver brings one itself (e.g. iwlwifi drivers).
Signed-off-by: Johannes Berg <johannes@sipsolutions.net>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/mac80211/rc80211_pid_algo.c')
-rw-r--r-- | net/mac80211/rc80211_pid_algo.c | 24 |
1 files changed, 22 insertions, 2 deletions
diff --git a/net/mac80211/rc80211_pid_algo.c b/net/mac80211/rc80211_pid_algo.c index da3529017da1..0995bb9cec21 100644 --- a/net/mac80211/rc80211_pid_algo.c +++ b/net/mac80211/rc80211_pid_algo.c | |||
@@ -12,7 +12,7 @@ | |||
12 | #include <linux/netdevice.h> | 12 | #include <linux/netdevice.h> |
13 | #include <linux/types.h> | 13 | #include <linux/types.h> |
14 | #include <linux/skbuff.h> | 14 | #include <linux/skbuff.h> |
15 | 15 | #include <linux/debugfs.h> | |
16 | #include <net/mac80211.h> | 16 | #include <net/mac80211.h> |
17 | #include "ieee80211_rate.h" | 17 | #include "ieee80211_rate.h" |
18 | 18 | ||
@@ -492,7 +492,7 @@ static void rate_control_pid_free_sta(void *priv, void *priv_sta) | |||
492 | kfree(spinfo); | 492 | kfree(spinfo); |
493 | } | 493 | } |
494 | 494 | ||
495 | struct rate_control_ops mac80211_rcpid = { | 495 | static struct rate_control_ops mac80211_rcpid = { |
496 | .name = "pid", | 496 | .name = "pid", |
497 | .tx_status = rate_control_pid_tx_status, | 497 | .tx_status = rate_control_pid_tx_status, |
498 | .get_rate = rate_control_pid_get_rate, | 498 | .get_rate = rate_control_pid_get_rate, |
@@ -507,3 +507,23 @@ struct rate_control_ops mac80211_rcpid = { | |||
507 | .remove_sta_debugfs = rate_control_pid_remove_sta_debugfs, | 507 | .remove_sta_debugfs = rate_control_pid_remove_sta_debugfs, |
508 | #endif | 508 | #endif |
509 | }; | 509 | }; |
510 | |||
511 | MODULE_DESCRIPTION("PID controller based rate control algorithm"); | ||
512 | MODULE_AUTHOR("Stefano Brivio"); | ||
513 | MODULE_AUTHOR("Mattias Nissler"); | ||
514 | MODULE_LICENSE("GPL"); | ||
515 | |||
516 | int __init rc80211_pid_init(void) | ||
517 | { | ||
518 | return ieee80211_rate_control_register(&mac80211_rcpid); | ||
519 | } | ||
520 | |||
521 | void __exit rc80211_pid_exit(void) | ||
522 | { | ||
523 | ieee80211_rate_control_unregister(&mac80211_rcpid); | ||
524 | } | ||
525 | |||
526 | #ifdef CONFIG_MAC80211_RC_PID_MODULE | ||
527 | module_init(rc80211_pid_init); | ||
528 | module_exit(rc80211_pid_exit); | ||
529 | #endif | ||