diff options
author | John W. Linville <linville@tuxdriver.com> | 2011-01-05 16:06:25 -0500 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2011-01-05 16:06:25 -0500 |
commit | c96e96354a6c9456cdf1f150eca504e2ea35301e (patch) | |
tree | 751bec601fb8152116b8e31e0f1f83d687a37d6f /drivers/net/wireless/airo.c | |
parent | dbbe68bb12b34f3e450da7a73c20e6fa1f85d63a (diff) | |
parent | 33af88138b859f515b365a074e0a014d7cdbf846 (diff) |
Merge branch 'master' of git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-next-2.6 into for-davem
Conflicts:
net/bluetooth/Makefile
Diffstat (limited to 'drivers/net/wireless/airo.c')
-rw-r--r-- | drivers/net/wireless/airo.c | 20 |
1 files changed, 7 insertions, 13 deletions
diff --git a/drivers/net/wireless/airo.c b/drivers/net/wireless/airo.c index a36e7870b03e..57a79b0475f6 100644 --- a/drivers/net/wireless/airo.c +++ b/drivers/net/wireless/airo.c | |||
@@ -4652,24 +4652,18 @@ static ssize_t proc_write( struct file *file, | |||
4652 | size_t len, | 4652 | size_t len, |
4653 | loff_t *offset ) | 4653 | loff_t *offset ) |
4654 | { | 4654 | { |
4655 | loff_t pos = *offset; | 4655 | ssize_t ret; |
4656 | struct proc_data *priv = file->private_data; | 4656 | struct proc_data *priv = file->private_data; |
4657 | 4657 | ||
4658 | if (!priv->wbuffer) | 4658 | if (!priv->wbuffer) |
4659 | return -EINVAL; | 4659 | return -EINVAL; |
4660 | 4660 | ||
4661 | if (pos < 0) | 4661 | ret = simple_write_to_buffer(priv->wbuffer, priv->maxwritelen, offset, |
4662 | return -EINVAL; | 4662 | buffer, len); |
4663 | if (pos >= priv->maxwritelen) | 4663 | if (ret > 0) |
4664 | return 0; | 4664 | priv->writelen = max_t(int, priv->writelen, *offset); |
4665 | if (len > priv->maxwritelen - pos) | 4665 | |
4666 | len = priv->maxwritelen - pos; | 4666 | return ret; |
4667 | if (copy_from_user(priv->wbuffer + pos, buffer, len)) | ||
4668 | return -EFAULT; | ||
4669 | if ( pos + len > priv->writelen ) | ||
4670 | priv->writelen = len + file->f_pos; | ||
4671 | *offset = pos + len; | ||
4672 | return len; | ||
4673 | } | 4667 | } |
4674 | 4668 | ||
4675 | static int proc_status_open(struct inode *inode, struct file *file) | 4669 | static int proc_status_open(struct inode *inode, struct file *file) |