Re: [PATCH] USB: add driver for LabJack USB DAQ devices

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 12/1/06, Greg KH <[email protected]> wrote:
On Fri, Dec 01, 2006 at 01:37:22PM -0700, David Lopez wrote:
> From: David Lopez <[email protected]>


The patch seems linewrapped, which doesn't make it easy to apply :(

Can you resend this?

Sorry about that.  Is it ok to send the patch as an attachment?  It
seems like gmail likes to linewrap plain text.  Also, when I resend
the patch after a little fixing should I send it as a reply.


> +#define BULK_IN_TIMEOUT                      1000    /* default bulk in
> read timeout */

What units is this timeout in?

It is in milliseconds.  I'll add that to the comment when I resend the patch.


> +static void ljusb_write_bulk_callback(struct urb *urb)
> +{
> +     struct usb_ljusb *dev;
> +
> +     dev = (struct usb_ljusb *)urb->context;
> +
> +     /* sync/async unlink faults aren't errors */
> +     if (urb->status &&
> +         !(urb->status == -ENOENT ||
> +           urb->status == -ECONNRESET ||
> +           urb->status == -ESHUTDOWN)) {
> +             dbg("%s - nonzero write bulk status received: %d",
> +                 __FUNCTION__, urb->status);
> +     }

A switch statement might work a bit better here.  It will let you handle
the different values you might get in a saner way.

This was taken from USB skeleton driver, and nothing more needs to be
added or changed for error handling, that I could think of now
anyways.


> +/**
> + *   ljusb_ioctl
> + */
> +static int ljusb_ioctl (struct inode *inode, struct file *file,
> unsigned int cmd, unsigned long arg)

New ioctls are pretty much frowned apon to add.  Do you _really_ need
these?

Can you use sysfs instead?

> +     /* driver specific commands */
> +     switch (cmd) {
> +             /* Sets the timeout for usb_bulk_msg reads transfers in ms
> from an integer
> +              * argument.  If the timeout is set to zero, reads will wait
> forever */
> +             case IOCTL_LJ_SET_BULK_IN_TIMEOUT:
> +                     data = (void __user *) arg;
> +                     if (data == NULL)
> +                             break;
> +
> +                     if (copy_from_user(&timeout, data, sizeof(int))) {
> +                             retval = -EFAULT;
> +                             break;
> +                     }
> +
> +                     if(timeout < 0)
> +                             retval = -EINVAL;
> +                     else
> +                             dev->bulk_in_timeout = timeout;
> +
> +                     break;

Is this really needed to be modified?

No this really isn't needed.  I'll take it out.


> +             /* Gets the Product ID for the device */
> +             case IOCTL_LJ_GET_PRODUCT_ID:
> +                     retval = put_user(dev->udev->descriptor.idProduct,
> +                                             (unsigned int __user *)arg);
> +                     break;

You can get this from sysfs or usbfs today.  Don't duplicate it please.

I didn't look at sysfs or usbfs.  I just needed a way to determine the
device from a device node in /dev from user space, and it seemed easy
to use ioctl.



> +             /* Sets the bulk in endpoint for the next read from an
> integer argument.
> +              * There are two bulk endpoints, which are endpoints 0 and 1
> when
> +              * setting the integer argument. */
> +             case IOCTL_LJ_SET_BULK_IN_ENDPOINT:
> +                     data = (void __user *) arg;
> +                     if (data == NULL)
> +                             break;
> +
> +                     if (copy_from_user(&ep, data, sizeof(int))) {
> +                             retval = -EFAULT;
> +                             break;
> +                     }
> +
> +                     if(ep > N_BULK_IN_ENDPOINTS || ep < 0)
> +                             retval = -EINVAL;
> +                     else
> +                             dev->next_bulk_in_endpoint = ep;
> +                     break;

Why is this needed?

The devices have a stream mode which can only be read from the second
bulk in endpoint.  All other communications are done from the first
bulk in and bulk out endpoints, and I needed some way to indicate that
the the next read should be from second bulk in endpoint keeping in
mind that first bulk in endpoint can still be used.  Is there a better
way to do this?


Thanks,
David
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

[Index of Archives]     [Kernel Newbies]     [Netfilter]     [Bugtraq]     [Photo]     [Stuff]     [Gimp]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Video 4 Linux]     [Linux for the blind]     [Linux Resources]
  Powered by Linux