parent
069e000642
commit
ed20dee7e6
@ -0,0 +1 @@
|
|||||||
|
# Calculate append=skip
|
@ -0,0 +1 @@
|
|||||||
|
# Calculate append=skip merge()!=
|
@ -0,0 +1,116 @@
|
|||||||
|
# Calculate format=diff pkg(sys-kernel/calculate-sources)>=3.10&&pkg(sys-kernel/calculate-sources)<3.11&&merge(net-wireless/broadcom-sta)>=6.30.223.30&&merge(net-wireless/broadcom-sta)<6.30.223.31
|
||||||
|
diff -ru build.3.9/src/wl/sys/wl_linux.c build/src/wl/sys/wl_linux.c
|
||||||
|
--- build.3.9/src/wl/sys/wl_linux.c 2013-06-18 13:48:04.109167642 +0000
|
||||||
|
+++ build/src/wl/sys/wl_linux.c 2013-06-18 14:24:33.448198331 +0000
|
||||||
|
@@ -3236,7 +3236,7 @@
|
||||||
|
void
|
||||||
|
wl_tkip_printstats(wl_info_t *wl, bool group_key)
|
||||||
|
{
|
||||||
|
-#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 14)
|
||||||
|
+#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 14) && LINUX_VERSION_CODE < KERNEL_VERSION(3, 10, 0)
|
||||||
|
char debug_buf[512];
|
||||||
|
int idx;
|
||||||
|
if (wl->tkipmodops) {
|
||||||
|
@@ -3409,6 +3409,7 @@
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
+#if LINUX_VERSION_CODE < KERNEL_VERSION(3, 10, 0)
|
||||||
|
static int
|
||||||
|
wl_proc_read(char *buffer, char **start, off_t offset, int length, int *eof, void *data)
|
||||||
|
{
|
||||||
|
@@ -3463,19 +3464,90 @@
|
||||||
|
return length;
|
||||||
|
}
|
||||||
|
|
||||||
|
+#else
|
||||||
|
+
|
||||||
|
+static int
|
||||||
|
+wl_proc_read(struct seq_file *seq, void *offset)
|
||||||
|
+{
|
||||||
|
+ wl_info_t * wl = (wl_info_t *)seq->private;
|
||||||
|
+ int bcmerror, to_user;
|
||||||
|
+
|
||||||
|
+ WL_LOCK(wl);
|
||||||
|
+ bcmerror = wlc_ioctl(wl->wlc, WLC_GET_MONITOR, &to_user, sizeof(int), NULL);
|
||||||
|
+ WL_UNLOCK(wl);
|
||||||
|
+
|
||||||
|
+ seq_printf(seq, "%d\n", to_user);
|
||||||
|
+ return bcmerror;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static ssize_t wl_proc_write(struct file *file, const char __user *buff,
|
||||||
|
+ size_t length, loff_t *ppos)
|
||||||
|
+{
|
||||||
|
+ struct seq_file *seq = file->private_data;
|
||||||
|
+ wl_info_t * wl = (wl_info_t *)seq->private;
|
||||||
|
+ int bcmerror, from_user = 0;
|
||||||
|
+
|
||||||
|
+ if (length != 1) {
|
||||||
|
+ WL_ERROR(("%s: Invalid data length\n", __FUNCTION__));
|
||||||
|
+ return -EIO;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ if (copy_from_user(&from_user, buff, 1)) {
|
||||||
|
+ WL_ERROR(("%s: copy from user failed\n", __FUNCTION__));
|
||||||
|
+ return -EFAULT;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ if (from_user >= 0x30)
|
||||||
|
+ from_user -= 0x30;
|
||||||
|
+
|
||||||
|
+ WL_LOCK(wl);
|
||||||
|
+ bcmerror = wlc_ioctl(wl->wlc, WLC_SET_MONITOR, &from_user, sizeof(int), NULL);
|
||||||
|
+ WL_UNLOCK(wl);
|
||||||
|
+
|
||||||
|
+ if (bcmerror < 0) {
|
||||||
|
+ WL_ERROR(("%s: SET_MONITOR failed with %d\n", __FUNCTION__, bcmerror));
|
||||||
|
+ return -EIO;
|
||||||
|
+ }
|
||||||
|
+ *ppos += length;
|
||||||
|
+ return length;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static int wl_proc_open(struct inode *inode, struct file *file)
|
||||||
|
+{
|
||||||
|
+ return single_open(file, wl_proc_read, PDE_DATA(inode));
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+static const struct file_operations wl_proc_fops = {
|
||||||
|
+ .owner = THIS_MODULE,
|
||||||
|
+ .open = wl_proc_open,
|
||||||
|
+ .read = seq_read,
|
||||||
|
+ .write = wl_proc_write,
|
||||||
|
+ .llseek = seq_lseek,
|
||||||
|
+ .release = single_release,
|
||||||
|
+};
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
|
static int
|
||||||
|
wl_reg_proc_entry(wl_info_t *wl)
|
||||||
|
{
|
||||||
|
char tmp[32];
|
||||||
|
sprintf(tmp, "%s%d", HYBRID_PROC, wl->pub->unit);
|
||||||
|
- if ((wl->proc_entry = create_proc_entry(tmp, 0644, NULL)) == NULL) {
|
||||||
|
+
|
||||||
|
+#if LINUX_VERSION_CODE < KERNEL_VERSION(3, 10, 0)
|
||||||
|
+ wl->proc_entry = create_proc_entry(tmp, 0644, NULL);
|
||||||
|
+ if (wl->proc_entry) {
|
||||||
|
+ wl->proc_entry->read_proc = wl_proc_read;
|
||||||
|
+ wl->proc_entry->write_proc = wl_proc_write;
|
||||||
|
+ wl->proc_entry->data = wl;
|
||||||
|
+ }
|
||||||
|
+#else
|
||||||
|
+ wl->proc_entry = proc_create_data(tmp, 0644, NULL, &wl_proc_fops, wl);
|
||||||
|
+#endif
|
||||||
|
+ if (!wl->proc_entry) {
|
||||||
|
WL_ERROR(("%s: create_proc_entry %s failed\n", __FUNCTION__, tmp));
|
||||||
|
ASSERT(0);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
- wl->proc_entry->read_proc = wl_proc_read;
|
||||||
|
- wl->proc_entry->write_proc = wl_proc_write;
|
||||||
|
- wl->proc_entry->data = wl;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#ifdef WLOFFLD
|
Loading…
Reference in new issue