Merge branch 'topic/memdup_user' into for-linus
* topic/memdup_user: ALSA: sound/pci: use memdup_user() ALSA: sound/usb: use memdup_user() ALSA: sound/isa: use memdup_user() ALSA: sound/core: use memdup_user()
This commit is contained in:
@@ -202,15 +202,11 @@ snd_wavefront_fx_ioctl (struct snd_hwdep *sdev, struct file *file,
|
||||
"> 512 bytes to FX\n");
|
||||
return -EIO;
|
||||
}
|
||||
page_data = kmalloc(r.data[2] * sizeof(short), GFP_KERNEL);
|
||||
if (!page_data)
|
||||
return -ENOMEM;
|
||||
if (copy_from_user (page_data,
|
||||
(unsigned char __user *) r.data[3],
|
||||
r.data[2] * sizeof(short))) {
|
||||
kfree(page_data);
|
||||
return -EFAULT;
|
||||
}
|
||||
page_data = memdup_user((unsigned char __user *)
|
||||
r.data[3],
|
||||
r.data[2] * sizeof(short));
|
||||
if (IS_ERR(page_data))
|
||||
return PTR_ERR(page_data);
|
||||
pd = page_data;
|
||||
}
|
||||
|
||||
|
@@ -1664,12 +1664,11 @@ snd_wavefront_synth_ioctl (struct snd_hwdep *hw, struct file *file,
|
||||
break;
|
||||
|
||||
case WFCTL_WFCMD:
|
||||
wc = kmalloc(sizeof(*wc), GFP_KERNEL);
|
||||
if (! wc)
|
||||
return -ENOMEM;
|
||||
if (copy_from_user (wc, argp, sizeof (*wc)))
|
||||
err = -EFAULT;
|
||||
else if (wavefront_synth_control (acard, wc) < 0)
|
||||
wc = memdup_user(argp, sizeof(*wc));
|
||||
if (IS_ERR(wc))
|
||||
return PTR_ERR(wc);
|
||||
|
||||
if (wavefront_synth_control (acard, wc) < 0)
|
||||
err = -EIO;
|
||||
else if (copy_to_user (argp, wc, sizeof (*wc)))
|
||||
err = -EFAULT;
|
||||
|
مرجع در شماره جدید
Block a user