lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-id: <op.vi01gltn7p4s8u@pikus>
Date:	Tue, 14 Sep 2010 16:34:59 +0200
From:	Michał Nazarewicz <m.nazarewicz@...sung.com>
To:	linux-usb <linux-usb@...r.kernel.org>,
	Maurus Cuelenaere <mcuelenaere@...il.com>,
	Greg Kroah-Hartman <gregkh@...e.de>,
	Masayuki Ohtake <masa-korg@....okisemi.com>
Cc:	LKML <linux-kernel@...r.kernel.org>,
	Toshiharu Okada <okada533@....okisemi.com>,
	Takahiro Shimizu <shimizu394@....okisemi.com>,
	Tomoya Morinaga <morinaga526@....okisemi.com>,
	"Wang, Qi" <qi.wang@...el.com>,
	"Wang, Yong Y" <yong.y.wang@...el.com>,
	Andrew <andrew.chih.howe.khor@...el.com>,
	Intel OTC <joel.clark@...el.com>,
	"Foster, Margie" <margie.foster@...el.com>,
	Arjan <arjan@...ux.intel.com>
Subject: Re: [PATCH v2] USB device driver of Topcliff PCH

On Tue, 14 Sep 2010 10:43:42 +0200, Masayuki Ohtake <masa-korg@....okisemi.com> wrote:
> diff --git a/drivers/usb/gadget/Kconfig b/drivers/usb/gadget/Kconfig
> +config PCH_USBDEV
> +	tristate
> +	depends on USB_GADGET_PCH
> +	default USB_GADGET
> +	select USB_GADGET_SELECTED

What's the use of this symbol?  Why is it missing help and prompt?

> +/**
> + * struct pch_udc_data_dma_desc - Structure to hold DMA descriptor information
> + *				  for data
> + * @status:		Status quadlet
> + * @reserved:		Reserved
> + * @dataptr:		Buffer descriptor
> + * @next:		Next descriptor
> +*/
    ^ space missing.

> +/**
> + * union pch_udc_ep - Structure holding setup request data
> + *

Needless line.

> + * @data[2]:		8 bytes of setup data

Needless "[2]".

> + * @request:		setup request for gadget driver
> + */
> +union pch_udc_setup_data {
> +	u32		data[2];
> +	struct usb_ctrlrequest	request;
> +};

Besides, do you really need this union?

> +/**
> + * struct pch_udc_dev - Structure holding complete information
> + *			of the PCH USB device
> + *

Needless empty line.

> + * @gadget:		gadget driver data
> + * @driver:		reference to gadget driver bound
> + * @pdev:		reference to the PCI device
> + * @ep[PCH_UDC_EP_NUM]:	array of endpoints

Needless "[...]".

> + * @lock:		protects all state
> + * @active:		enabled the PCI device
> + * @stall:		stall requested
> + * @prot_stall:		protcol stall requested
> + * @irq_registered:	irq registered with system
> + * @mem_region:		device memory mapped
> + * @registered:		driver regsitered with system
> + * @suspended:		driver in suspended state
> + * @connected:		gadget driver associated
> + * @set_cfg_not_acked:	pending acknowledgement 4 setup
> + * @waiting_zlp_ack:	pending acknowledgement 4 ZLP
> + * @data_requests:	DMA pool for data requests
> + * @stp_requests:	DMA pool for setup requests
> + * @dma_addr:		DMA pool for received
> + * @ep0out_buf[64]:	Buffer for DMA
> + * @setup_data:		Received setup data
> + * @phys_addr:		of device memory
> + * @base_addr:		for mapped device memory
> + * @irq:		IRQ line for the device
> + * @cfg_data:		current cfg, intf, and alt in use
> + */

> +/* macro to set a specified bit(mask) at the specified address */
> +#define PCH_UDC_BIT_SET(dev, reg, bitmask) \
> +     pch_udc_writel((dev), ((pch_udc_readl((dev), (reg)) | (bitmask))), (reg))
> +
> +/* macro to clear a specified bit(mask) at the specified address */
> +#define PCH_UDC_BIT_CLR(dev, reg, bitMask) \
> +     pch_udc_writel((dev), (pch_udc_readl((dev), (reg)) & (~(bitMask))), (reg))

You might want to make it into a static inline -- it should make some
people more happy. ;) You can put it after the pch_udc_writel() function.

> +/**
> + * struct pch_udc_request - Structure holding a PCH USB device request
> + * @req:		embedded ep request
> + * @td_data_phys:	phys. address
> + * @td_data:		first dma desc. of chain
> + * @td_data_last:	last dma desc. of chain
> + * @queue:		associated queue
> + * @dma_going:		DMA in progress for request
> + * @dma_mapped:		DMA memory mapped for request
> + * @dma_done:		DMA completed for request
> + * @chain_len:		chain length
> + */
> +struct pch_udc_request /* request packet */
> +{

"{" should go at the same line as "struct".

> +	struct usb_request		req;
> +	dma_addr_t			td_data_phys;
> +	struct pch_udc_data_dma_desc	*td_data;
> +	struct pch_udc_data_dma_desc	*td_data_last;
> +	struct list_head		queue;
> +	unsigned			dma_going:1,
> +					dma_mapped:1,
> +					dma_done:1;
> +	unsigned			chain_len;
> +};

> +/**
> + * pch_udc_write_csr() - Write the command and status registers.
> + * @val:	value to be written to CSR register
> + * @addr:	address of CSR register
> + */
> +static void pch_udc_write_csr(struct pch_udc_dev *dev, unsigned long val,
> +			       unsigned long reg)
> +{
> +	unsigned int count = MAX_LOOP;
> +
> +	/* Wait till idle */
> +	while ((pch_udc_readl(dev, UDC_CSR_BUSY_ADDR) & UDC_CSR_BUSY)
> +		&& (count > 0))
> +		count--;

Come to think of it, you sort of ignore the result of the last read if
all possible loop iterations were done.  I mean, when count hits zero
you still read the register but it does not really matter what the
read value is.  Because of that, I'd change the while to:

+	while ((pch_udc_readl(...) & UDC_CSR_BUSY) && --count)
+		/* nop */;

This also applies to other loops in other functions as well.

> +	if (!count)
> +		dev_err(&dev->pdev->dev, "%s: wait error; count = %x",
> +			__func__, count);

Writing count here is rather useless.  It's always zero.
This also applies to other loops in other functions as well.

Besides, the loop repeats in four different places (if I notices all of them).
Why not make a function out of it?

> +	pch_udc_writel(dev, val, reg);
> +	/* Wait till idle */
> +	count = MAX_LOOP;
> +	while ((pch_udc_readl(dev, UDC_CSR_BUSY_ADDR) & UDC_CSR_BUSY)
> +		&& (count > 0))
> +		count--;
> +	if (!count)
> +		dev_err(&dev->pdev->dev, "%s: wait error; count = %x",
> +			__func__, count);
> +}

> +static u32 pch_udc_read_csr(struct pch_udc_dev *dev, unsigned long reg)
> +{
[...]
> +	/* Dummy read */
> +	pch_udc_readl(dev, reg);

O_o...  I'll just assume this makes sense for the hardware. ;)
A comment about why this is done in such a way would be nice
though.

[...]
> +}

> +static inline void pch_udc_vbus_session(struct pch_udc_dev *dev,
> +					  int is_active)
> +{
> +	if (is_active == 0)
> +		pch_udc_set_disconnect(dev);
> +	else
> +		pch_udc_clear_disconnect(dev);
> +}

> +static void pch_udc_ep_clear_nak(struct pch_udc_ep *ep)
> +{
> +	unsigned int loopcnt = 0;
> +	struct pch_udc_dev *dev = ep->dev;
> +
> +	if (!(pch_udc_readl(ep->dev, ep->offset_addr + UDC_EPCTL_ADDR) &
> +	      UDC_EPCTL_NAK))

Just a thought, but maybe it would be feasible to create pch_ep_readl()
and pch_ep_writel() functions so that you wouldn't have to add the
ep->offset_addr each time.

> +		return;
> +	if (!ep->in) {

Useless "{ ... }".

> +		while ((pch_udc_read_ep_status(ep) &
> +			UDC_EPSTS_MRXFIFO_EMP) == 0) {
> +			if (loopcnt++ > 100000) {

Why not preincrementation?  Why not loop form 100000 to zero rather
than from zero to 100000.

> +				dev_dbg(&dev->pdev->dev, "%s: RxFIFO not Empty "
> +					"loop count = %d", __func__, loopcnt);
> +				break;
> +			}
> +			udelay(100);
> +		}
> +	}

You need to zero loopcnt here.  Also, I'd use a loop from 25 to zero rather
than from zero to 25 here the same as above.

> +	while (pch_udc_readl(ep->dev, ep->offset_addr + UDC_EPCTL_ADDR) &
> +		UDC_EPCTL_NAK) {
> +		PCH_UDC_BIT_SET(ep->dev, ep->offset_addr + UDC_EPCTL_ADDR,
> +				UDC_EPCTL_CNAK);
> +		udelay(5);
> +		if (loopcnt++ >= 25) {
> +			dev_dbg(&dev->pdev->dev, "%s: Clear NAK not set "
> +				"for ep%d%s: counter=%d", __func__, ep->num,
> +				 (ep->in ? "in" : "out"), loopcnt);
> +			break;
> +		}
> +	}
> +}

> +static void pch_udc_ep_fifo_flush(struct pch_udc_ep *ep, int dir)
> +{
> +	unsigned int loopcnt = 0;
> +	struct pch_udc_dev *dev = ep->dev;
> +
> +	dev_dbg(&dev->pdev->dev, "%s: ep%d%s", __func__, ep->num,
> +		(ep->in ? "in" : "out"));
> +	if (dir) {	/* IN ep */
> +		PCH_UDC_BIT_SET(ep->dev, ep->offset_addr + UDC_EPCTL_ADDR,
> +				UDC_EPCTL_F);
> +		return;
> +	} else {

Drop "else", "{" ... "}" and indention.

> +		if (pch_udc_read_ep_status(ep) & UDC_EPSTS_MRXFIFO_EMP)
> +			return;
> +		PCH_UDC_BIT_SET(ep->dev, ep->offset_addr + UDC_EPCTL_ADDR,
> +				UDC_EPCTL_MRXFLUSH);
> +		/* Wait for RxFIFO Empty */
> +		while ((pch_udc_read_ep_status(ep) &
> +			UDC_EPSTS_MRXFIFO_EMP) == 0) {
> +			if (loopcnt++ > 1000000) {
> +				dev_dbg(&dev->pdev->dev, "RxFIFO not Empty "
> +					"loop count = %d", loopcnt);
> +				break;
> +			}
> +			udelay(100);
> +		}
> +		PCH_UDC_BIT_CLR(ep->dev, ep->offset_addr + UDC_EPCTL_ADDR,
> +				UDC_EPCTL_MRXFLUSH);
> +	}
> +}

> +static void pch_udc_init(struct pch_udc_dev *dev)
> +{
[...]
> +	/* enable dynamic CSR programmingi, self powered and device speed */
> +	if (speed_fs) {
> +		PCH_UDC_BIT_SET(dev, UDC_DEVCFG_ADDR, UDC_DEVCFG_CSR_PRG |
> +				UDC_DEVCFG_SP | UDC_DEVCFG_SPD_FS);
> +	} else { /* defaul high speed */
> +		PCH_UDC_BIT_SET(dev, UDC_DEVCFG_ADDR, UDC_DEVCFG_CSR_PRG |
> +				UDC_DEVCFG_SP | UDC_DEVCFG_SPD_HS);
> +	}

Useless "{ ... }".

[...]
> +}

> +static int pch_udc_pcd_pullup(struct usb_gadget *gadget, int is_on)
> +{
> +	struct pch_udc_dev	*dev;
> +
> +	if (gadget == NULL) {
> +		pr_debug("%s: exit -EINVAL", __func__);
> +		return -EINVAL;
> +	}
> +	dev = container_of(gadget, struct pch_udc_dev, gadget);
> +	if (is_on == 0)
> +		pch_udc_set_disconnect(dev);
> +	else
> +		pch_udc_clear_disconnect(dev);
> +	return 0;

You can use pch_udc_vbus_session() here.

> +}

> +static int pch_udc_pcd_vbus_draw(struct usb_gadget *gadget, unsigned int mA)
> +{
> +	if ((gadget == NULL) || (mA > 250)) { /* Max is 250 in 2mA unit */
> +		pr_debug("%s: exit -EINVAL", __func__);
> +		return -EINVAL;
> +	}
> +	/* Could not find any regs where we can set the limit	*/
> +	return -EOPNOTSUPP;
> +}

Wouldn't it be easier to just always return -EOPNOTSUPP?

> +const struct usb_gadget_ops pch_udc_ops = {

Why not static?

> +	.get_frame = pch_udc_pcd_get_frame,
> +	.wakeup = pch_udc_pcd_wakeup,
> +	.set_selfpowered = pch_udc_pcd_selfpowered,
> +	.pullup = pch_udc_pcd_pullup,
> +	.vbus_session = pch_udc_pcd_vbus_session,
> +	.vbus_draw = pch_udc_pcd_vbus_draw,
> +};

> +static void complete_req(struct pch_udc_ep *ep, struct pch_udc_request *req,
> +								 int status)
> +{

> +	if (req->dma_mapped) {
> +		if (ep->in) {
> +			pci_unmap_single(dev->pdev, req->req.dma,
> +					 req->req.length, PCI_DMA_TODEVICE);
> +		} else {
> +			pci_unmap_single(dev->pdev, req->req.dma,
> +					 req->req.length, PCI_DMA_FROMDEVICE);
> +		}

Useless "{ ... }".

> +		req->dma_mapped = 0;
> +		req->req.dma = DMA_ADDR_INVALID;
> +	}

> +}
> +
> +/**
> + * empty_req_queue() - This API empties the request queue of an endpoint
> + * @ep:		Reference to the endpoint structure
> + */
> +static void empty_req_queue(struct pch_udc_ep *ep)
> +{
> +	struct pch_udc_request	*req;
> +
> +	ep->halted = 1;
> +	while (!list_empty(&ep->queue)) {
> +		req = list_entry(ep->queue.next, struct pch_udc_request, queue);
> +		pr_debug("%s: complete_req  ep%d%s", __func__, ep->num,
> +			  (ep->in ? "in" : "out"));
> +		complete_req(ep, req, -ESHUTDOWN);

complete_req() removes from list, right? I think it's worth adding a comment.

> +	}
> +}


> +static int pch_udc_create_dma_chain(struct pch_udc_ep *ep,
> +				     struct pch_udc_request *req,
> +				     unsigned long buf_len,
> +				     gfp_t gfp_flags)
> +{

> +	for (i = buf_len; i < bytes; i += buf_len) {
> +		dma_addr = DMA_ADDR_INVALID;
> +		/* create or determine next desc. */
> +		td = pci_pool_alloc(ep->dev->data_requests, gfp_flags,
> +				    &dma_addr);
> +		if (td == NULL)
> +			return -ENOMEM;
> +
> +		td->status = 0;
> +		td->dataptr = req->req.dma + i; /* assign buffer */
> +
> +		if ((bytes - i) >= buf_len) {
> +			txbytes = buf_len;
> +		} else { /* short packet */
> +			txbytes = bytes - i;
> +		}

Useless "{ ... }".

> +static int prepare_dma(struct pch_udc_ep *ep, struct pch_udc_request *req,
> +			  gfp_t gfp)
> +{

> +	/* Allocate and create a DMA chain */
> +	retval = pch_udc_create_dma_chain(ep, req, ep->ep.maxpacket, gfp);
> +	if (retval) {
> +		if (retval == -ENOMEM)
> +			pr_err("%s: Out of DMA memory", __func__);
> +		return retval;
> +	}
> +	if (ep->in) {
> +		if (req->req.length <= ep->ep.maxpacket) {
> +			/* write tx bytes */
> +			req->td_data->status = PCH_UDC_DMA_LAST |
> +					       PCH_UDC_BS_HST_BSY |
> +					       req->req.length;
> +		}

Useless "{ ... "}".

> +/**
> + * process_zlp() - This function process zero length packets
> + *			from the gadget driver
> + * @ep:		Reference to the endpoint structure
> + * @req:	Reference to the request
> + */
> +static void process_zlp(struct pch_udc_ep *ep, struct pch_udc_request *req)
> +{
> +	struct pch_udc_dev	*dev = ep->dev;
> +
> +	dev_dbg(&dev->pdev->dev, "%s: enter  ep%d%s", __func__, ep->num,
> +		(ep->in ? "in" : "out"));
> +	/* IN zlp's are handled by hardware */
> +	complete_req(ep, req, 0);
> +
> +	/* if set_config or set_intf is waiting for ack by zlp
> +	 *then set CSR_DONE
             ^ missing space.


> +	 */

> +	/* setup command is ACK'ed now by zlp */
> +	if (!dev->stall) {
> +		if (dev->waiting_zlp_ack) {

Join both ifs into a single if with &&.

> +			/* clear NAK by writing CNAK in EP0_IN */
> +			pch_udc_ep_clear_nak(&(dev->ep[UDC_EP0IN_IDX]));
> +			dev->waiting_zlp_ack = 0;
> +		}
> +	}
> +}
> +
> +/**
> + * pch_udc_start_rxrequest() - This function starts the receive requirement.
> + * @ep:		Reference to the endpoint structure
> + * @req:	Reference to the request structure
> + */
> +static void pch_udc_start_rxrequest(struct pch_udc_ep *ep,
> +					 struct pch_udc_request *req)
> +{
> +	struct pch_udc_data_dma_desc *td_data;
> +
> +	pch_udc_clear_dma(ep->dev, DMA_DIR_RX);
> +	td_data = req->td_data;
> +	ep->td_data = req->td_data;
> +	/* Set the status bits for all descriptors */
> +	while (1) {
> +		td_data->status = (td_data->status & ~PCH_UDC_BUFF_STS) |
> +				    PCH_UDC_BS_HST_RDY;
> +		if ((td_data->status & PCH_UDC_DMA_LAST) ==  PCH_UDC_DMA_LAST)
> +			break;
> +
> +		td_data = (struct pch_udc_data_dma_desc *) \
> +			   phys_to_virt(td_data->next);

Useless cast.  phys_to_virt() returns void*.

> +	}

> +		if (ep->in) {
> +			usbreq->dma = pci_map_single(dev->pdev, usbreq->buf,
> +					usbreq->length, PCI_DMA_TODEVICE);
> +		} else {
> +			usbreq->dma = pci_map_single(dev->pdev, usbreq->buf,
> +					usbreq->length, PCI_DMA_FROMDEVICE);
> +		}

Useless "{ ... }".

> +static void pch_udc_complete_transfer(struct pch_udc_ep *ep)
> +{
> +	struct pch_udc_request *req;
> +	struct pch_udc_dev *dev = ep->dev;
> +
> +	if (list_empty(&ep->queue))
> +		return;
> +
> +	dev_dbg(&dev->pdev->dev, "%s: list_entry", __func__);
> +	req = list_entry(ep->queue.next, struct pch_udc_request, queue);
> +	if (!req)
> +		return;

This can never happen.  list_head's next is never set to NULL.  Moreover,
you already check if the queue is not empty a few lines above.

> +	if ((req->td_data_last->status & PCH_UDC_BUFF_STS) !=
> +						PCH_UDC_BS_DMA_DONE)
> +		return;
> +
> +#ifdef DMA_PPB_WITH_DESC_UPDATE
> +	for (i = 0; i < req->chain_len; i++) {

> +		req->td_data = (struct pch_udc_data_dma_desc *)
> +				 phys_to_virt(req->td_data->next);

Useless cast.

> +	}
> +#else

> +#endif

> +static void pch_udc_complete_receiver(struct pch_udc_ep *ep)
> +{
> +	struct pch_udc_request *req;
> +	struct pch_udc_dev *dev = ep->dev;
> +	unsigned int count;
> +
> +	if (list_empty(&ep->queue))
> +		return;
> +
> +	/* next request */
> +	req = list_entry(ep->queue.next, struct pch_udc_request, queue);
> +	if (!req || (req->td_data_last->status & PCH_UDC_BUFF_STS) !=
> +						PCH_UDC_BS_DMA_DONE) {
> +#ifdef DMA_PPB_WITH_DESC_UPDATE
> +		dev_dbg(&dev->pdev->dev, "%s: ep%d%s  DMA not Done",
> +			__func__, ep->num, (ep->in ? "in" : "out"));
> +		pch_udc_ep_set_rrdy(ep);
> +#endif
> +		return;
> +	}
> +	dev_dbg(&dev->pdev->dev, "%s: ep%d%s  DMA Done", __func__, ep->num,
> +		 (ep->in ? "in" : "out"));
> +	/* Disable DMA */
> +	pch_udc_clear_dma(ep->dev, DMA_DIR_RX);
> +#ifdef DMA_PPB_WITH_DESC_UPDATE
> +{

This should be indented.

> +	/* Get Rx bytes */
> +	struct pch_udc_data_dma_desc *td_data = req->td_data;
> +	for (i = 0, count = 0; i < req->chain_len; i++) {
> +		if ((td_data->status & PCH_UDC_RXTX_STS) != PCH_UDC_RTS_SUCC) {
> +			dev_err(&dev->pdev->dev, "Invalid RXTX status (0x%08x) "
> +				"epstatus=0x%08x\n",
> +				(td_data->status & PCH_UDC_RXTX_STS),
> +				(int)(ep->epsts));
> +			return;
> +		}
> +		count += td_data->status & PCH_UDC_RXTX_BYTES;
> +		td_data =
> +		  (struct pch_udc_data_dma_desc *) phys_to_virt(td_data->next);

Useless cast.
> +	}
> +}
> +#else

> +#endif

> +/**
> + * pch_udc_svc_data_out() - Handles interrupts from OUT endpoint
> + * @dev:	Reference to the device structure
> + * @ep_num:	Endpoint that generated the interrupt
> + */
> +static void pch_udc_svc_data_out(struct pch_udc_dev *dev, int ep_num)
> +{
> +	u32			epsts;
> +	struct pch_udc_ep		*ep;
> +	struct pch_udc_request		*req = NULL;
> +
> +	ep = &dev->ep[2*ep_num + 1];
> +	epsts = ep->epsts;
> +	ep->epsts = 0;
> +
> +	dev_dbg(&dev->pdev->dev, "%s: enter  ep%d%s status = 0x%08x", __func__,
> +		ep->num, (ep->in ? "in" : "out"), epsts);
> +	if (epsts & UDC_EPSTS_BNA) { /* Just log it; only in DMA mode */
> +		if (!list_empty(&ep->queue)) {

Those two ifs can be joined into one with &&.

[...]
> +		}
> +	}

> +}
> +
> +/**
> + * pch_udc_svc_control_in() - Handle Control IN endpoint interrupts
> + * @dev:	Reference to the device structure
> + */
> +static void pch_udc_svc_control_in(struct pch_udc_dev *dev)
> +{

> +	if (epsts & UDC_EPSTS_TXEMPTY) { /* Tx empty */
> +		dev_dbg(&dev->pdev->dev, "%s: TXEMPTY", __func__);
> +	}

Useless "{ ... }".

> +}
> +
> +/**
> + * pch_udc_svc_control_out() - Routine that handle Control
> + *					OUT endpoint interrupts
> + * @dev:	Reference to the device structure
> + */
> +static void pch_udc_svc_control_out(struct pch_udc_dev *dev)
> +{
> +	u32	stat;
> +	int setup_supported;
> +	struct pch_udc_ep	*ep;
> +
> +	ep = &dev->ep[UDC_EP0OUT_IDX];
> +	stat = ep->epsts;
> +	ep->epsts = 0;
> +
> +	if (stat & UDC_EPSTS_BNA)
> +		dev_dbg(&dev->pdev->dev, "%s: EP0: BNA", __func__);
> +		/* When we get a request, we will populate the descriptors. */
> +		/* Anything else to do? */
> +	/* If setup data */
> +	if (((stat & UDC_EPSTS_OUT_MASK) >> UDC_EPSTS_OUT_OFS) ==
> +	    UDC_EPSTS_OUT_SETUP) {
> +		dev->stall = 0;
> +		dev->ep[UDC_EP0IN_IDX].halted = 0;
> +		dev->ep[UDC_EP0OUT_IDX].halted = 0;
> +		/* In data not ready */
> +		pch_udc_ep_set_nak(&(dev->ep[UDC_EP0IN_IDX]));
> +		dev->setup_data.data[0] = ep->td_stp->data12;
> +		dev->setup_data.data[1] = ep->td_stp->data34;
> +		dev_dbg(&dev->pdev->dev, "%s: EP0 setup data12: 0x%x "
> +			"data34:0x%x", __func__, ep->td_stp->data12,
> +			ep->td_stp->data34);
> +		pch_udc_init_setup_buff(ep->td_stp);
> +		pch_udc_clear_dma(dev, DMA_DIR_TX);
> +		pch_udc_ep_fifo_flush(&(dev->ep[UDC_EP0IN_IDX]),
> +				      dev->ep[UDC_EP0IN_IDX].in);
> +		if ((dev->setup_data.request.bRequestType & USB_DIR_IN) != 0) {
> +			dev->gadget.ep0 = &dev->ep[UDC_EP0IN_IDX].ep;
> +		} else { /*	OUT */
> +			dev->gadget.ep0 = &ep->ep;
> +		}

Useless "{ ... }".

> +static void pch_udc_dev_isr(struct pch_udc_dev *dev, u32 dev_intr)
> +{
[...]
> +	/* RWKP interrupt */
> +	if (dev_intr & UDC_DEVINT_RWKP)
> +		dev_dbg(&dev->pdev->dev, "RWKP");
> +

Useless empty line.

> +}

> +static void pch_udc_pcd_reinit(struct pch_udc_dev *dev)
> +{
> +	static const char *ep_string[] = {

Why not static "const char *const ep_string[]"?

> +		ep0_string, "ep0out", "ep1in", "ep1out", "ep2in", "ep2out",
> +		"ep3in", "ep3out", "ep4in", "ep4out", "ep5in", "ep5out",
> +		"ep6in", "ep6out", "ep7in", "ep7out", "ep8in", "ep8out",
> +		"ep9in", "ep9out", "ep10in", "ep10out", "ep11in", "ep11out",
> +		"ep12in", "ep12out", "ep13in", "ep13out", "ep14in", "ep14out",
> +		"ep15in", "ep15out",
> +	};

> +}

Also, please run checkpatch.pl on the patch.

-- 
Best regards,                                        _     _
| Humble Liege of Serenely Enlightened Majesty of  o' \,=./ `o
| Computer Science,  Michał "mina86" Nazarewicz       (o o)
+----[mina86*mina86.com]---[mina86*jabber.org]----ooO--(_)--Ooo--
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ