hc
2025-02-14 bbb9540dc49f70f6b703d1c8d1b85fa5f602d86e
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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
// SPDX-License-Identifier: GPL-2.0-only
/*
 * cfg80211 debugfs
 *
 * Copyright 2009    Luis R. Rodriguez <lrodriguez@atheros.com>
 * Copyright 2007    Johannes Berg <johannes@sipsolutions.net>
 */
 
#include <linux/slab.h>
#include "core.h"
#include "debugfs.h"
 
#define DEBUGFS_READONLY_FILE(name, buflen, fmt, value...)        \
static ssize_t name## _read(struct file *file, char __user *userbuf,    \
               size_t count, loff_t *ppos)            \
{                                    \
   struct wiphy *wiphy = file->private_data;            \
   char buf[buflen];                        \
   int res;                            \
                                   \
   res = scnprintf(buf, buflen, fmt "\n", ##value);        \
   return simple_read_from_buffer(userbuf, count, ppos, buf, res);    \
}                                    \
                                   \
static const struct file_operations name## _ops = {            \
   .read = name## _read,                        \
   .open = simple_open,                        \
   .llseek = generic_file_llseek,                    \
}
 
DEBUGFS_READONLY_FILE(rts_threshold, 20, "%d",
             wiphy->rts_threshold);
DEBUGFS_READONLY_FILE(fragmentation_threshold, 20, "%d",
             wiphy->frag_threshold);
DEBUGFS_READONLY_FILE(short_retry_limit, 20, "%d",
             wiphy->retry_short);
DEBUGFS_READONLY_FILE(long_retry_limit, 20, "%d",
             wiphy->retry_long);
 
static int ht_print_chan(struct ieee80211_channel *chan,
            char *buf, int buf_size, int offset)
{
   if (WARN_ON(offset > buf_size))
       return 0;
 
   if (chan->flags & IEEE80211_CHAN_DISABLED)
       return scnprintf(buf + offset,
                buf_size - offset,
                "%d Disabled\n",
                chan->center_freq);
 
   return scnprintf(buf + offset,
            buf_size - offset,
            "%d HT40 %c%c\n",
            chan->center_freq,
            (chan->flags & IEEE80211_CHAN_NO_HT40MINUS) ?
               ' ' : '-',
            (chan->flags & IEEE80211_CHAN_NO_HT40PLUS) ?
               ' ' : '+');
}
 
static ssize_t ht40allow_map_read(struct file *file,
                 char __user *user_buf,
                 size_t count, loff_t *ppos)
{
   struct wiphy *wiphy = file->private_data;
   char *buf;
   unsigned int offset = 0, buf_size = PAGE_SIZE, i;
   enum nl80211_band band;
   struct ieee80211_supported_band *sband;
   ssize_t r;
 
   buf = kzalloc(buf_size, GFP_KERNEL);
   if (!buf)
       return -ENOMEM;
 
   rtnl_lock();
 
   for (band = 0; band < NUM_NL80211_BANDS; band++) {
       sband = wiphy->bands[band];
       if (!sband)
           continue;
       for (i = 0; i < sband->n_channels; i++)
           offset += ht_print_chan(&sband->channels[i],
                       buf, buf_size, offset);
   }
 
   rtnl_unlock();
 
   r = simple_read_from_buffer(user_buf, count, ppos, buf, offset);
 
   kfree(buf);
 
   return r;
}
 
static const struct file_operations ht40allow_map_ops = {
   .read = ht40allow_map_read,
   .open = simple_open,
   .llseek = default_llseek,
};
 
#define DEBUGFS_ADD(name)                        \
   debugfs_create_file(#name, 0444, phyd, &rdev->wiphy, &name## _ops)
 
void cfg80211_debugfs_rdev_add(struct cfg80211_registered_device *rdev)
{
   struct dentry *phyd = rdev->wiphy.debugfsdir;
 
   DEBUGFS_ADD(rts_threshold);
   DEBUGFS_ADD(fragmentation_threshold);
   DEBUGFS_ADD(short_retry_limit);
   DEBUGFS_ADD(long_retry_limit);
   DEBUGFS_ADD(ht40allow_map);
}