Commit 32702e96 authored by Jack Pham's avatar Jack Pham Committed by Felipe Balbi

usb: dwc3: gadget: Iterate only over valid endpoints

Make dwc3_gadget_resize_tx_fifos() iterate only over IN
endpoints that are actually present, based on the
num_in_eps parameter. This terminates the loop so as to
prevent dereferencing a potential NULL dwc->eps[i] where
i >= (num_in_eps + num_out_eps).
Signed-off-by: default avatarJack Pham <jackp@codeaurora.org>
Signed-off-by: default avatarFelipe Balbi <balbi@ti.com>
parent 8b2bc2c9
...@@ -187,15 +187,12 @@ int dwc3_gadget_resize_tx_fifos(struct dwc3 *dwc) ...@@ -187,15 +187,12 @@ int dwc3_gadget_resize_tx_fifos(struct dwc3 *dwc)
* improve this algorithm so that we better use the internal * improve this algorithm so that we better use the internal
* FIFO space * FIFO space
*/ */
for (num = 0; num < DWC3_ENDPOINTS_NUM; num++) { for (num = 0; num < dwc->num_in_eps; num++) {
struct dwc3_ep *dep = dwc->eps[num]; /* bit0 indicates direction; 1 means IN ep */
int fifo_number = dep->number >> 1; struct dwc3_ep *dep = dwc->eps[(num << 1) | 1];
int mult = 1; int mult = 1;
int tmp; int tmp;
if (!(dep->number & 1))
continue;
if (!(dep->flags & DWC3_EP_ENABLED)) if (!(dep->flags & DWC3_EP_ENABLED))
continue; continue;
...@@ -224,8 +221,7 @@ int dwc3_gadget_resize_tx_fifos(struct dwc3 *dwc) ...@@ -224,8 +221,7 @@ int dwc3_gadget_resize_tx_fifos(struct dwc3 *dwc)
dev_vdbg(dwc->dev, "%s: Fifo Addr %04x Size %d\n", dev_vdbg(dwc->dev, "%s: Fifo Addr %04x Size %d\n",
dep->name, last_fifo_depth, fifo_size & 0xffff); dep->name, last_fifo_depth, fifo_size & 0xffff);
dwc3_writel(dwc->regs, DWC3_GTXFIFOSIZ(fifo_number), dwc3_writel(dwc->regs, DWC3_GTXFIFOSIZ(num), fifo_size);
fifo_size);
last_fifo_depth += (fifo_size & 0xffff); last_fifo_depth += (fifo_size & 0xffff);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment