Re: [PATCH v2 47/48] usb: musb: gadget: add musb_match_ep() function

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

 



Hello.

On 7/14/2015 12:39 PM, Robert Baldyga wrote:

Add 'match_ep' callback to utilize chip-specific knowledge in endpoint matching
process. Functions does the same that was done by chip-specific code inside
of epautoconf. Now this code can be removed from there to separate generic code
from platform specific logic.

Signed-off-by: Robert Baldyga <r.baldyga@xxxxxxxxxxx>

[...]
diff --git a/drivers/usb/musb/musb_gadget.c b/drivers/usb/musb/musb_gadget.c
index 043248a..5f1eb35 100644
--- a/drivers/usb/musb/musb_gadget.c
+++ b/drivers/usb/musb/musb_gadget.c
@@ -1684,6 +1684,49 @@ static int musb_gadget_pullup(struct usb_gadget *gadget, int is_on)
  	return 0;
  }

+#ifdef CONFIG_BLACKFIN
+static struct usb_ep *musb_find_ep(struct usb_gadget *g,
+		const char *name)
+{
+	struct usb_ep *ep;
+
+	list_for_each_entry(ep, &g->ep_list, ep_list) {
+		if (0 == strcmp(ep->name, name))

   Please make the immediate value the 2nd operand of ==.

+			return ep;
+	}
+
+	return NULL;
+}
+
+static struct usb_ep *match_match_ep(struct usb_gadget *g,
+		struct usb_endpoint_descriptor *desc,
+		struct usb_ss_ep_comp_descriptor *ep_comp)
+{
+	struct usb_ep *ep = NULL;
+	u8 type = usb_endpoint_type(desc);
+
+	if ((USB_ENDPOINT_XFER_BULK == type) ||
+			(USB_ENDPOINT_XFER_ISOC == type)) {

   Likewise.

+		if (USB_DIR_IN & desc->bEndpointAddress)

   The same about &.

+			ep = musb_find_ep(g, "ep5in");
+		else
+			ep = musb_find_ep(g, "ep6out");
+	} else if (USB_ENDPOINT_XFER_INT == type) {

   Likewise.

+		if (USB_DIR_IN & desc->bEndpointAddress)
+			ep = musb_find_ep(g, "ep1in");
+		else
+			ep = musb_find_ep(g, "ep2out");
+	}

   This string of *if* statements is asking to be *switch* instead.

[...]

WBR, Sergei

_______________________________________________
devel mailing list
devel@xxxxxxxxxxxxxxxxxxxxxx
http://driverdev.linuxdriverproject.org/mailman/listinfo/driverdev-devel



[Index of Archives]     [Linux Driver Backports]     [DMA Engine]     [Linux GPIO]     [Linux SPI]     [Video for Linux]     [Linux USB Devel]     [Linux Coverity]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Yosemite Backpacking]
  Powered by Linux