Blame view
net/mac80211/rc80211_minstrel_debugfs.c
7.38 KB
cccf129f8 mac80211: add the... |
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 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 |
/* * Copyright (C) 2008 Felix Fietkau <nbd@openwrt.org> * * 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. * * Based on minstrel.c: * Copyright (C) 2005-2007 Derek Smithies <derek@indranet.co.nz> * Sponsored by Indranet Technologies Ltd * * Based on sample.c: * Copyright (c) 2005 John Bicket * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer, * without modification. * 2. Redistributions in binary form must reproduce at minimum a disclaimer * similar to the "NO WARRANTY" disclaimer below ("Disclaimer") and any * redistribution must be conditioned upon including a substantially * similar Disclaimer requirement for further binary redistribution. * 3. Neither the names of the above-listed copyright holders nor the names * of any contributors may be used to endorse or promote products derived * from this software without specific prior written permission. * * Alternatively, this software may be distributed under the terms of the * GNU General Public License ("GPL") version 2 as published by the Free * Software Foundation. * * NO WARRANTY * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF NONINFRINGEMENT, MERCHANTIBILITY * AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL * THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER * IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF * THE POSSIBILITY OF SUCH DAMAGES. */ #include <linux/netdevice.h> #include <linux/types.h> #include <linux/skbuff.h> #include <linux/debugfs.h> #include <linux/ieee80211.h> |
5a0e3ad6a include cleanup: ... |
52 |
#include <linux/slab.h> |
bc3b2d7fb net: Add export.h... |
53 |
#include <linux/export.h> |
cccf129f8 mac80211: add the... |
54 55 |
#include <net/mac80211.h> #include "rc80211_minstrel.h" |
6d4885177 mac80211: add new... |
56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 |
ssize_t minstrel_stats_read(struct file *file, char __user *buf, size_t len, loff_t *ppos) { struct minstrel_debugfs_info *ms; ms = file->private_data; return simple_read_from_buffer(buf, len, ppos, ms->buf, ms->len); } int minstrel_stats_release(struct inode *inode, struct file *file) { kfree(file->private_data); return 0; } |
eae44756d minstrel: make th... |
71 |
int |
cccf129f8 mac80211: add the... |
72 73 74 |
minstrel_stats_open(struct inode *inode, struct file *file) { struct minstrel_sta_info *mi = inode->i_private; |
44ac91ea8 minstrel: simplif... |
75 |
struct minstrel_debugfs_info *ms; |
50e55a8ea mac80211: add max... |
76 |
unsigned int i, tp_max, tp_avg, prob, eprob; |
cccf129f8 mac80211: add the... |
77 |
char *p; |
11b2357d5 mac80211: minstre... |
78 |
ms = kmalloc(2048, GFP_KERNEL); |
cccf129f8 mac80211: add the... |
79 80 81 82 83 |
if (!ms) return -ENOMEM; file->private_data = ms; p = ms->buf; |
e161f7f6c mac80211: enhance... |
84 85 |
p += sprintf(p, " "); |
a0c391b13 mac80211: minstre... |
86 87 88 89 90 91 |
p += sprintf(p, "best __________rate_________ ________statistics________ ________last_______ ______sum-of________ "); p += sprintf(p, "rate [name idx airtime max_tp] [avg(tp) avg(prob) sd(prob)] [prob.|retry|suc|att] [#success | #attempts] "); |
e161f7f6c mac80211: enhance... |
92 |
|
cccf129f8 mac80211: add the... |
93 94 |
for (i = 0; i < mi->n_rates; i++) { struct minstrel_rate *mr = &mi->r[i]; |
ca12c0c83 mac80211: Unify r... |
95 |
struct minstrel_rate_stats *mrs = &mi->r[i].stats; |
cccf129f8 mac80211: add the... |
96 |
|
2ff2b690c mac80211: improve... |
97 98 99 100 |
*(p++) = (i == mi->max_tp_rate[0]) ? 'A' : ' '; *(p++) = (i == mi->max_tp_rate[1]) ? 'B' : ' '; *(p++) = (i == mi->max_tp_rate[2]) ? 'C' : ' '; *(p++) = (i == mi->max_tp_rate[3]) ? 'D' : ' '; |
cccf129f8 mac80211: add the... |
101 |
*(p++) = (i == mi->max_prob_rate) ? 'P' : ' '; |
e161f7f6c mac80211: enhance... |
102 103 |
p += sprintf(p, " %3u%s ", mr->bitrate / 2, |
cccf129f8 mac80211: add the... |
104 |
(mr->bitrate & 1 ? ".5" : " ")); |
e161f7f6c mac80211: enhance... |
105 |
p += sprintf(p, "%3u ", i); |
50e55a8ea mac80211: add max... |
106 |
p += sprintf(p, "%6u ", mr->perfect_tx_time); |
cccf129f8 mac80211: add the... |
107 |
|
50e55a8ea mac80211: add max... |
108 109 |
tp_max = minstrel_get_tp_avg(mr, MINSTREL_FRAC(100,100)); tp_avg = minstrel_get_tp_avg(mr, mrs->prob_ewma); |
ca12c0c83 mac80211: Unify r... |
110 |
prob = MINSTREL_TRUNC(mrs->cur_prob * 1000); |
9134073bc mac80211: improve... |
111 |
eprob = MINSTREL_TRUNC(mrs->prob_ewma * 1000); |
cccf129f8 mac80211: add the... |
112 |
|
a0c391b13 mac80211: minstre... |
113 |
p += sprintf(p, "%4u.%1u %4u.%1u %3u.%1u %3u.%1u" |
5f919abc7 mac80211: add sta... |
114 115 116 |
" %3u.%1u %3u %3u %-3u " "%9llu %-9llu ", |
50e55a8ea mac80211: add max... |
117 |
tp_max / 10, tp_max % 10, |
6a27b2c40 mac80211: restruc... |
118 |
tp_avg / 10, tp_avg % 10, |
cccf129f8 mac80211: add the... |
119 |
eprob / 10, eprob % 10, |
5f919abc7 mac80211: add sta... |
120 |
mrs->prob_ewmsd / 10, mrs->prob_ewmsd % 10, |
cccf129f8 mac80211: add the... |
121 |
prob / 10, prob % 10, |
e161f7f6c mac80211: enhance... |
122 |
mrs->retry_count, |
ca12c0c83 mac80211: Unify r... |
123 124 125 126 |
mrs->last_success, mrs->last_attempts, (unsigned long long)mrs->succ_hist, (unsigned long long)mrs->att_hist); |
cccf129f8 mac80211: add the... |
127 128 129 130 131 132 |
} p += sprintf(p, " Total packet count:: ideal %d " "lookaround %d ", |
ca12c0c83 mac80211: Unify r... |
133 134 |
mi->total_packets - mi->sample_packets, mi->sample_packets); |
cccf129f8 mac80211: add the... |
135 |
ms->len = p - ms->buf; |
11b2357d5 mac80211: minstre... |
136 |
WARN_ON(ms->len + sizeof(*ms) > 2048); |
cccf129f8 mac80211: add the... |
137 138 |
return 0; } |
6d4885177 mac80211: add new... |
139 140 141 142 143 144 145 146 147 148 |
static const struct file_operations minstrel_stat_fops = { .owner = THIS_MODULE, .open = minstrel_stats_open, .read = minstrel_stats_read, .release = minstrel_stats_release, .llseek = default_llseek, }; int minstrel_stats_csv_open(struct inode *inode, struct file *file) |
cccf129f8 mac80211: add the... |
149 |
{ |
6d4885177 mac80211: add new... |
150 |
struct minstrel_sta_info *mi = inode->i_private; |
44ac91ea8 minstrel: simplif... |
151 |
struct minstrel_debugfs_info *ms; |
50e55a8ea mac80211: add max... |
152 |
unsigned int i, tp_max, tp_avg, prob, eprob; |
6d4885177 mac80211: add new... |
153 |
char *p; |
cccf129f8 mac80211: add the... |
154 |
|
6d4885177 mac80211: add new... |
155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 |
ms = kmalloc(2048, GFP_KERNEL); if (!ms) return -ENOMEM; file->private_data = ms; p = ms->buf; for (i = 0; i < mi->n_rates; i++) { struct minstrel_rate *mr = &mi->r[i]; struct minstrel_rate_stats *mrs = &mi->r[i].stats; p += sprintf(p, "%s" ,((i == mi->max_tp_rate[0]) ? "A" : "")); p += sprintf(p, "%s" ,((i == mi->max_tp_rate[1]) ? "B" : "")); p += sprintf(p, "%s" ,((i == mi->max_tp_rate[2]) ? "C" : "")); p += sprintf(p, "%s" ,((i == mi->max_tp_rate[3]) ? "D" : "")); p += sprintf(p, "%s" ,((i == mi->max_prob_rate) ? "P" : "")); p += sprintf(p, ",%u%s", mr->bitrate / 2, (mr->bitrate & 1 ? ".5," : ",")); p += sprintf(p, "%u,", i); p += sprintf(p, "%u,",mr->perfect_tx_time); |
50e55a8ea mac80211: add max... |
176 177 |
tp_max = minstrel_get_tp_avg(mr, MINSTREL_FRAC(100,100)); tp_avg = minstrel_get_tp_avg(mr, mrs->prob_ewma); |
6d4885177 mac80211: add new... |
178 |
prob = MINSTREL_TRUNC(mrs->cur_prob * 1000); |
9134073bc mac80211: improve... |
179 |
eprob = MINSTREL_TRUNC(mrs->prob_ewma * 1000); |
6d4885177 mac80211: add new... |
180 |
|
5f919abc7 mac80211: add sta... |
181 |
p += sprintf(p, "%u.%u,%u.%u,%u.%u,%u.%u,%u.%u,%u,%u,%u," |
6d4885177 mac80211: add new... |
182 183 |
"%llu,%llu,%d,%d ", |
50e55a8ea mac80211: add max... |
184 |
tp_max / 10, tp_max % 10, |
6a27b2c40 mac80211: restruc... |
185 |
tp_avg / 10, tp_avg % 10, |
6d4885177 mac80211: add new... |
186 |
eprob / 10, eprob % 10, |
5f919abc7 mac80211: add sta... |
187 |
mrs->prob_ewmsd / 10, mrs->prob_ewmsd % 10, |
6d4885177 mac80211: add new... |
188 189 190 191 192 193 194 195 196 197 198 199 200 |
prob / 10, prob % 10, mrs->retry_count, mrs->last_success, mrs->last_attempts, (unsigned long long)mrs->succ_hist, (unsigned long long)mrs->att_hist, mi->total_packets - mi->sample_packets, mi->sample_packets); } ms->len = p - ms->buf; WARN_ON(ms->len + sizeof(*ms) > 2048); |
cccf129f8 mac80211: add the... |
201 |
|
cccf129f8 mac80211: add the... |
202 203 |
return 0; } |
6d4885177 mac80211: add new... |
204 |
static const struct file_operations minstrel_stat_csv_fops = { |
cccf129f8 mac80211: add the... |
205 |
.owner = THIS_MODULE, |
6d4885177 mac80211: add new... |
206 |
.open = minstrel_stats_csv_open, |
cccf129f8 mac80211: add the... |
207 208 |
.read = minstrel_stats_read, .release = minstrel_stats_release, |
6038f373a llseek: automatic... |
209 |
.llseek = default_llseek, |
cccf129f8 mac80211: add the... |
210 211 212 213 214 215 216 217 218 |
}; void minstrel_add_sta_debugfs(void *priv, void *priv_sta, struct dentry *dir) { struct minstrel_sta_info *mi = priv_sta; mi->dbg_stats = debugfs_create_file("rc_stats", S_IRUGO, dir, mi, &minstrel_stat_fops); |
6d4885177 mac80211: add new... |
219 220 221 |
mi->dbg_stats_csv = debugfs_create_file("rc_stats_csv", S_IRUGO, dir, mi, &minstrel_stat_csv_fops); |
cccf129f8 mac80211: add the... |
222 223 224 225 226 227 228 229 |
} void minstrel_remove_sta_debugfs(void *priv, void *priv_sta) { struct minstrel_sta_info *mi = priv_sta; debugfs_remove(mi->dbg_stats); |
6d4885177 mac80211: add new... |
230 231 |
debugfs_remove(mi->dbg_stats_csv); |
cccf129f8 mac80211: add the... |
232 |
} |