3 Broadcom B43 wireless driver
7 Copyright (c) 2006 Michael Buesch <mb@bu3sch.de>
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 2 of the License, or
12 (at your option) any later version.
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
19 You should have received a copy of the GNU General Public License
20 along with this program; see the file COPYING. If not, write to
21 the Free Software Foundation, Inc., 51 Franklin Steet, Fifth Floor,
22 Boston, MA 02110-1301, USA.
31 #include <linux/capability.h>
33 #define GENERIC_FILESIZE 64
35 static int get_integer(const char *buf
, size_t count
)
37 char tmp
[10 + 1] = { 0 };
42 count
= min(count
, (size_t) 10);
43 memcpy(tmp
, buf
, count
);
44 ret
= simple_strtol(tmp
, NULL
, 10);
49 static int get_boolean(const char *buf
, size_t count
)
56 if (count
>= 4 && memcmp(buf
, "true", 4) == 0)
58 if (count
>= 5 && memcmp(buf
, "false", 5) == 0)
60 if (count
>= 3 && memcmp(buf
, "yes", 3) == 0)
62 if (count
>= 2 && memcmp(buf
, "no", 2) == 0)
64 if (count
>= 2 && memcmp(buf
, "on", 2) == 0)
66 if (count
>= 3 && memcmp(buf
, "off", 3) == 0)
72 static ssize_t
b43_attr_interfmode_show(struct device
*dev
,
73 struct device_attribute
*attr
,
76 struct b43_wldev
*wldev
= dev_to_b43_wldev(dev
);
79 if (!capable(CAP_NET_ADMIN
))
82 mutex_lock(&wldev
->wl
->mutex
);
84 switch (wldev
->phy
.interfmode
) {
85 case B43_INTERFMODE_NONE
:
87 snprintf(buf
, PAGE_SIZE
,
88 "0 (No Interference Mitigation)\n");
90 case B43_INTERFMODE_NONWLAN
:
92 snprintf(buf
, PAGE_SIZE
,
93 "1 (Non-WLAN Interference Mitigation)\n");
95 case B43_INTERFMODE_MANUALWLAN
:
97 snprintf(buf
, PAGE_SIZE
,
98 "2 (WLAN Interference Mitigation)\n");
104 mutex_unlock(&wldev
->wl
->mutex
);
109 static ssize_t
b43_attr_interfmode_store(struct device
*dev
,
110 struct device_attribute
*attr
,
111 const char *buf
, size_t count
)
113 struct b43_wldev
*wldev
= dev_to_b43_wldev(dev
);
118 if (!capable(CAP_NET_ADMIN
))
121 mode
= get_integer(buf
, count
);
124 mode
= B43_INTERFMODE_NONE
;
127 mode
= B43_INTERFMODE_NONWLAN
;
130 mode
= B43_INTERFMODE_MANUALWLAN
;
133 mode
= B43_INTERFMODE_AUTOWLAN
;
139 mutex_lock(&wldev
->wl
->mutex
);
140 spin_lock_irqsave(&wldev
->wl
->irq_lock
, flags
);
142 err
= b43_radio_set_interference_mitigation(wldev
, mode
);
144 b43err(wldev
->wl
, "Interference Mitigation not "
145 "supported by device\n");
148 spin_unlock_irqrestore(&wldev
->wl
->irq_lock
, flags
);
149 mutex_unlock(&wldev
->wl
->mutex
);
151 return err
? err
: count
;
154 static DEVICE_ATTR(interference
, 0644,
155 b43_attr_interfmode_show
, b43_attr_interfmode_store
);
157 static ssize_t
b43_attr_preamble_show(struct device
*dev
,
158 struct device_attribute
*attr
, char *buf
)
160 struct b43_wldev
*wldev
= dev_to_b43_wldev(dev
);
163 if (!capable(CAP_NET_ADMIN
))
166 mutex_lock(&wldev
->wl
->mutex
);
168 if (wldev
->short_preamble
)
170 snprintf(buf
, PAGE_SIZE
, "1 (Short Preamble enabled)\n");
173 snprintf(buf
, PAGE_SIZE
, "0 (Short Preamble disabled)\n");
175 mutex_unlock(&wldev
->wl
->mutex
);
180 static ssize_t
b43_attr_preamble_store(struct device
*dev
,
181 struct device_attribute
*attr
,
182 const char *buf
, size_t count
)
184 struct b43_wldev
*wldev
= dev_to_b43_wldev(dev
);
188 if (!capable(CAP_NET_ADMIN
))
191 value
= get_boolean(buf
, count
);
194 mutex_lock(&wldev
->wl
->mutex
);
195 spin_lock_irqsave(&wldev
->wl
->irq_lock
, flags
);
197 wldev
->short_preamble
= !!value
;
199 spin_unlock_irqrestore(&wldev
->wl
->irq_lock
, flags
);
200 mutex_unlock(&wldev
->wl
->mutex
);
205 static DEVICE_ATTR(shortpreamble
, 0644,
206 b43_attr_preamble_show
, b43_attr_preamble_store
);
208 int b43_sysfs_register(struct b43_wldev
*wldev
)
210 struct device
*dev
= wldev
->dev
->dev
;
213 B43_WARN_ON(b43_status(wldev
) != B43_STAT_INITIALIZED
);
215 err
= device_create_file(dev
, &dev_attr_interference
);
218 err
= device_create_file(dev
, &dev_attr_shortpreamble
);
220 goto err_remove_interfmode
;
224 err_remove_interfmode
:
225 device_remove_file(dev
, &dev_attr_interference
);
229 void b43_sysfs_unregister(struct b43_wldev
*wldev
)
231 struct device
*dev
= wldev
->dev
->dev
;
233 device_remove_file(dev
, &dev_attr_shortpreamble
);
234 device_remove_file(dev
, &dev_attr_interference
);