Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 27 Feb 2009 05:43:05 -0800
From:      Andrew Thompson <thompsa@FreeBSD.org>
To:        Hans Petter Selasky <hselasky@c2i.net>
Cc:        usb@freebsd.org, freebsd-current@freebsd.org
Subject:   Re: USB devfs patch
Message-ID:  <20090227134305.GA53460@citylink.fud.org.nz>
In-Reply-To: <200902270843.12291.hselasky@c2i.net>
References:  <20090226020330.GC25211@citylink.fud.org.nz> <20090227011434.GA52500@citylink.fud.org.nz> <200902270843.12291.hselasky@c2i.net>

next in thread | previous in thread | raw e-mail | index | archive | help
On Fri, Feb 27, 2009 at 08:43:11AM +0100, Hans Petter Selasky wrote:
> Hi Andrew,
> 
> > The patch has been updated thanks to feedback
> > http://people.freebsd.org/~thompsa/usb-cdevs2.diff
> 
> I cannot see that you have looked at the 11 issues I repored on the last 
> patch. Can you have a look at the following issues again:

Yes I have, 1, 2, 3, 6, 7 & 8 have all been fixed. For #10 use
http://fxr.watson.org


Andrew 
> Here is a list of comments and bugs.
> The comments follow the diff from top to bottom.
> 
> 1) There is a redundant setting of "is_uref = 1" ?
> 
> - ? ? ? if (ploc->is_uref) {
> + ? ? ? if (cpd->is_uref) {
> ? ? ? ? ? ? ? ? /*
> ? ? ? ? ? ? ? ? ?* We are about to alter the bus-state. Apply the
> ? ? ? ? ? ? ? ? ?* required locks.
> ? ? ? ? ? ? ? ? ?*/
> - ? ? ? ? ? ? ? sx_xlock(ploc->udev->default_sx + 1);
> + ? ? ? ? ? ? ? sx_xlock(cpd->udev->default_sx + 1);
> ? ? ? ? ? ? ? ? mtx_lock(&Giant); ? ? ? /* XXX */
> + ? ? ? ? ? ? ? cpd->is_uref = 1;
> ? ? ? ? }
> 
> 
> 2) Should gid_t uid_t and mode_t be used?
> 
> + ? ?uint8_t iface_index, uint32_t uid, uint32_t gid, uint16_t mode)
> 
> 
> 3) This comment should be:
> 
> /* Now, create the device itself and an alias */
> 
> /* Now, create the device */
> 
> Because the alias is not needed - right.
> 
> 
> 4) Probably you can just remove the src_path stuff:
> 
> + ? ? ? /* XXX no longer needed */
> + ? ? ? strlcpy(ps->src_path, target, sizeof(ps->src_path));
> + ? ? ? ps->src_len = strlen(ps->src_path);
> 
> 5) There is no reason to use 32-bit int, except for fflags?
> 
> uint16_t bus_index;
> uint8_t dev_index;
> uint8_t iface_index;
> uint8_t ep_addr;
> #define?EP_NO_ADDR 0xff /* instead of ep_addr = -1 */
> 
> ?/*
> + * Private per-device information.
> + */
> +struct usb2_cdev_privdata {
> + ? ? ? struct usb2_bus ? ? ? ? *bus;
> + ? ? ? struct usb2_device ? ? ?*udev;
> + ? ? ? struct usb2_interface ? *iface;
> + ? ? ? struct usb2_fifo ? ? ? ?*rxfifo;
> + ? ? ? struct usb2_fifo ? ? ? ?*txfifo;
> + ? ? ? int ? ? ? ? ? ? ? ? ? ? bus_index; ? ? ?/* bus index */
> + ? ? ? int ? ? ? ? ? ? ? ? ? ? dev_index; ? ? ?/* device index */
> + ? ? ? int ? ? ? ? ? ? ? ? ? ? iface_index; ? ?/* interface index */
> + ? ? ? int ? ? ? ? ? ? ? ? ? ? ep_addr; ? ? ? ?/* endpoint address */
> + ? ? ? uint8_t ? ? ? ? ? ? ? ? fifo_index; ? ? /* FIFO index */
> + ? ? ? uint8_t ? ? ? ? ? ? ? ? is_read; ? ? ? ?/* location has read access */
> + ? ? ? uint8_t ? ? ? ? ? ? ? ? is_write; ? ? ? /* location has write access 
> */
> + ? ? ? uint8_t ? ? ? ? ? ? ? ? is_uref; ? ? ? ?/* USB refcount decr. needed 
> */
> + ? ? ? uint8_t ? ? ? ? ? ? ? ? is_usbfs; ? ? ? /* USB-FS is active */
> + ? ? ? int ? ? ? ? ? ? ? ? ? ? fflags;
> +};
> 
> For usb2_fs_privdata probably you are justified. I would have used 
> "unsigned int" for the fields that are unsigned. It has something to do with
> range checks in the code not checking for values less than zero. Like:
> 
> if (fifo_index < max)
> ok;
> else
> failure;
> 
> With int's we have to think more:
> 
> if (fifo_index >= 0 && fifo_index < max)
> ok;
> else
> failure;
> 
> 6) Some non-gcc compilers will complain unless you do 0-1 when the
> destination variable is unsigned.
> 
> - ? ? ? usb2_free_pipe_data(udev, iface_index, 0 - 1);
> + ? ? ? usb2_free_pipe_data(udev, iface_index, -1);
> 
> 
> 7) Watch out!! Maybe using the word "in" and "out" is bad idea. If
> this means "read" and "write", then use "rd" and "wr", because in USB
> device mode the endpoint direction is exactly the opposide like in USB
> host mode:
> 
> + ? ? ? ? ? ? ? /* Fill in the endpoint bitmasks */
> + ? ? ? ? ? ? ? if (ed->bEndpointAddress & UE_DIR_IN)
> + ? ? ? ? ? ? ? ? ? ? ? iface->ep_in_mask |=
> + ? ? ? ? ? ? ? ? ? ? ? ? ? 1 << UE_GET_ADDR(ed->bEndpointAddress);
> + ? ? ? ? ? ? ? else
> + ? ? ? ? ? ? ? ? ? ? ? iface->ep_out_mask |=
> + ? ? ? ? ? ? ? ? ? ? ? ? ? 1 << UE_GET_ADDR(ed->bEndpointAddress);
> 
> Use the the following macro for reference when computing if an
> endpoint is read or write!
> 
> #define USB_GET_DATA_ISREAD(xfer) (((xfer)->flags_int.usb2_mode == \
> ? ? ? ? USB_MODE_DEVICE) ? ((xfer->endpoint & UE_DIR_IN) ? 0 : 1) : \
> ? ? ? ? ((xfer->endpoint & UE_DIR_IN) ? 1 : 0))
> 
> Change:
> 
> + ? ? ? uint16_t ep_in_mask; ? ? ? ? ? ?/* bitmask of IN endpoints */
> + ? ? ? uint16_t ep_out_mask; ? ? ? ? ? /* bitmask of OUT endpoints */
> 
> Into:
> 
> + ? ? ? uint16_t ep_rx_mask; ? ? ? ? ? ?/* bitmask of RX endpoints */
> + ? ? ? uint16_t ep_tx_mask; ? ? ? ? ? /* bitmask of TX endpoints */
> 
> 
> 8) The following won't work?? Freeing the cdevs have to be done in multiple
> steps. Please keep the semantics of the "usb2_fifo_free_wrap" function.
> 
> When setting the configuration we have a cdev handle on EP0. If that
> is closed during set_config we are recursivly killing our own handle!
> Therefore there are some extra checks so that at some points we only
> free non-EP0 handles, at some point only a specific interface and so
> on.
> 
> + ? ? ? usb2_cdev_free(udev);
> ? ? ? ? usb2_fifo_free_wrap(udev, iface_index, 0);
> 
> 9) Regarding the device nodes, how about organising into sub-folders?
> 
> Before:
> 
> + ? ? ? ? ? ? ? ? ? ? ? /* Now, create the device itself */
> + ? ? ? ? ? ? ? ? ? ? ? snprintf(devname, sizeof(devname), USB_DEVICE_NAME
> + ? ? ? ? ? ? ? ? ? ? ? ? ? "%u.%u.%u.%u", pd->bus_index, pd->dev_index,
> + ? ? ? ? ? ? ? ? ? ? ? ? ? pd->iface_index, pd->ep_addr);
> +
> 
> After:
> 
> + ? ? ? ? ? ? ? ? ? ? ? /* Now, create the device itself */
> + ? ? ? ? ? ? ? ? ? ? ? snprintf(devname, sizeof(devname), USB_DEVICE_NAME
> + ? ? ? ? ? ? ? ? ? ? ? ? ? "%u/%u/%u/%u", pd->bus_index, pd->dev_index,
> + ? ? ? ? ? ? ? ? ? ? ? ? ? pd->iface_index, pd->ep_addr);
> +
> 
> You would also have to update libusb20.
> 
> 10) Can you show me the implementation of the following function:
> 
> + ? ? ? devfs_set_cdevpriv(cpd, usb2_close);
> 
> --HPS



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20090227134305.GA53460>