fix kernel module bugs
This commit is contained in:
parent
84d04e6d7e
commit
1d890a2aa2
|
@ -56,7 +56,8 @@ static ssize_t dmj_char_read(struct file *file, char *buf, size_t len, loff_t *l
|
||||||
if (len > INT_MAX) return -EINVAL;
|
if (len > INT_MAX) return -EINVAL;
|
||||||
ilen = (int)len;
|
ilen = (int)len;
|
||||||
|
|
||||||
res = dmj_transfer(dmjch->pdev, -1, DMJ_XFER_FLAGS_FILL_RECVBUF, NULL, 0, &kbuf, &ilen);
|
/* no flags: act like libusb read */
|
||||||
|
res = dmj_transfer(dmjch->pdev, -1, 0/*DMJ_XFER_FLAGS_FILL_RECVBUF*/, NULL, 0, &kbuf, &ilen);
|
||||||
if (res < 0 || ilen < 0 || !kbuf) {
|
if (res < 0 || ilen < 0 || !kbuf) {
|
||||||
if (kbuf) kfree(kbuf);
|
if (kbuf) kfree(kbuf);
|
||||||
return (res >= 0) ? -EIO : ret;
|
return (res >= 0) ? -EIO : ret;
|
||||||
|
|
|
@ -227,7 +227,7 @@ int dmj_xfer_internal(struct dmj_dev *dmj, int cmd, int recvflags,
|
||||||
* will error when going beyond!). also done in 64b chunks
|
* will error when going beyond!). also done in 64b chunks
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (!rbuf || !rbufsize || *rbufsize <= 0) return 0;
|
if (!rbufsize || *rbufsize <= 0) return 0;
|
||||||
|
|
||||||
if (recvflags & DMJ_XFER_FLAGS_FILL_RECVBUF) {
|
if (recvflags & DMJ_XFER_FLAGS_FILL_RECVBUF) {
|
||||||
tmpbuf = kmalloc(64, GFP_KERNEL);
|
tmpbuf = kmalloc(64, GFP_KERNEL);
|
||||||
|
@ -265,7 +265,7 @@ int dmj_xfer_internal(struct dmj_dev *dmj, int cmd, int recvflags,
|
||||||
ret = usb_bulk_msg(dmj->usb_dev, usb_rcvbulkpipe(dmj->usb_dev, dmj->ep_in),
|
ret = usb_bulk_msg(dmj->usb_dev, usb_rcvbulkpipe(dmj->usb_dev, dmj->ep_in),
|
||||||
longbuf, *rbufsize, rbufsize, DMJ_USB_TIMEOUT);
|
longbuf, *rbufsize, rbufsize, DMJ_USB_TIMEOUT);
|
||||||
if (ret < 0) goto err_freelong;
|
if (ret < 0) goto err_freelong;
|
||||||
if (actual < 0) { ret = -EREMOTEIO; goto err_freelong; }
|
if (*rbufsize < 0) ret = -EREMOTEIO; goto err_freelong;
|
||||||
|
|
||||||
ret = 0;
|
ret = 0;
|
||||||
*rbuf = longbuf;
|
*rbuf = longbuf;
|
||||||
|
|
Loading…
Reference in New Issue