提交 70fdb273 编写于 作者: F Felipe Balbi

usb: dwc3: get rid of DWC3_TRB_MASK

instead of using a bitwise and, let's rely on the %
operator since that's a lot more clear. Also, GCC
will optimize % 256 to nothing anyway.
Signed-off-by: NFelipe Balbi <felipe.balbi@linux.intel.com>
上级 c28f8259
...@@ -440,7 +440,6 @@ struct dwc3_event_buffer { ...@@ -440,7 +440,6 @@ struct dwc3_event_buffer {
#define DWC3_EP_DIRECTION_RX false #define DWC3_EP_DIRECTION_RX false
#define DWC3_TRB_NUM 256 #define DWC3_TRB_NUM 256
#define DWC3_TRB_MASK (DWC3_TRB_NUM - 1)
/** /**
* struct dwc3_ep - device side endpoint representation * struct dwc3_ep - device side endpoint representation
......
...@@ -160,8 +160,8 @@ void dwc3_gadget_giveback(struct dwc3_ep *dep, struct dwc3_request *req, ...@@ -160,8 +160,8 @@ void dwc3_gadget_giveback(struct dwc3_ep *dep, struct dwc3_request *req,
* DWC3_TRBCTL_LINK_TRB because it points the TRB we * DWC3_TRBCTL_LINK_TRB because it points the TRB we
* just completed (not the LINK TRB). * just completed (not the LINK TRB).
*/ */
if (((dep->trb_dequeue & DWC3_TRB_MASK) == if (((dep->trb_dequeue % DWC3_TRB_NUM) ==
DWC3_TRB_NUM- 1) && DWC3_TRB_NUM - 1) &&
usb_endpoint_xfer_isoc(dep->endpoint.desc)) usb_endpoint_xfer_isoc(dep->endpoint.desc))
dep->trb_dequeue++; dep->trb_dequeue++;
} while(++i < req->request.num_mapped_sgs); } while(++i < req->request.num_mapped_sgs);
...@@ -741,18 +741,18 @@ static void dwc3_prepare_one_trb(struct dwc3_ep *dep, ...@@ -741,18 +741,18 @@ static void dwc3_prepare_one_trb(struct dwc3_ep *dep,
chain ? " chain" : ""); chain ? " chain" : "");
trb = &dep->trb_pool[dep->trb_enqueue & DWC3_TRB_MASK]; trb = &dep->trb_pool[dep->trb_enqueue % DWC3_TRB_NUM];
if (!req->trb) { if (!req->trb) {
dwc3_gadget_move_started_request(req); dwc3_gadget_move_started_request(req);
req->trb = trb; req->trb = trb;
req->trb_dma = dwc3_trb_dma_offset(dep, trb); req->trb_dma = dwc3_trb_dma_offset(dep, trb);
req->first_trb_index = dep->trb_enqueue & DWC3_TRB_MASK; req->first_trb_index = dep->trb_enqueue % DWC3_TRB_NUM;
} }
dep->trb_enqueue++; dep->trb_enqueue++;
/* Skip the LINK-TRB on ISOC */ /* Skip the LINK-TRB on ISOC */
if (((dep->trb_enqueue & DWC3_TRB_MASK) == DWC3_TRB_NUM - 1) && if (((dep->trb_enqueue % DWC3_TRB_NUM) == DWC3_TRB_NUM - 1) &&
usb_endpoint_xfer_isoc(dep->endpoint.desc)) usb_endpoint_xfer_isoc(dep->endpoint.desc))
dep->trb_enqueue++; dep->trb_enqueue++;
...@@ -826,11 +826,11 @@ static void dwc3_prepare_trbs(struct dwc3_ep *dep, bool starting) ...@@ -826,11 +826,11 @@ static void dwc3_prepare_trbs(struct dwc3_ep *dep, bool starting)
BUILD_BUG_ON_NOT_POWER_OF_2(DWC3_TRB_NUM); BUILD_BUG_ON_NOT_POWER_OF_2(DWC3_TRB_NUM);
/* the first request must not be queued */ /* the first request must not be queued */
trbs_left = (dep->trb_dequeue - dep->trb_enqueue) & DWC3_TRB_MASK; trbs_left = (dep->trb_dequeue - dep->trb_enqueue) % DWC3_TRB_NUM;
/* Can't wrap around on a non-isoc EP since there's no link TRB */ /* Can't wrap around on a non-isoc EP since there's no link TRB */
if (!usb_endpoint_xfer_isoc(dep->endpoint.desc)) { if (!usb_endpoint_xfer_isoc(dep->endpoint.desc)) {
max = DWC3_TRB_NUM - (dep->trb_enqueue & DWC3_TRB_MASK); max = DWC3_TRB_NUM - (dep->trb_enqueue % DWC3_TRB_NUM);
if (trbs_left > max) if (trbs_left > max)
trbs_left = max; trbs_left = max;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册