提交 e7839f99 编写于 作者: J John Youn 提交者: Felipe Balbi

usb: dwc2: Rename the dma_enable parameter to host_dma

Rename it so that it is more consistent with the gadget dma parameter.
It only affects host-mode operation so prefix it with "host".
Signed-off-by: NJohn Youn <johnyoun@synopsys.com>
Signed-off-by: NFelipe Balbi <felipe.balbi@linux.intel.com>
上级 05ee799f
...@@ -286,7 +286,7 @@ enum dwc2_ep0_state { ...@@ -286,7 +286,7 @@ enum dwc2_ep0_state {
* @otg_ver: OTG version supported * @otg_ver: OTG version supported
* 0 - 1.3 (default) * 0 - 1.3 (default)
* 1 - 2.0 * 1 - 2.0
* @dma_enable: Specifies whether to use slave or DMA mode for accessing * @host_dma: Specifies whether to use slave or DMA mode for accessing
* the data FIFOs. The driver will automatically detect the * the data FIFOs. The driver will automatically detect the
* value for this parameter if none is specified. * value for this parameter if none is specified.
* 0 - Slave (always available) * 0 - Slave (always available)
...@@ -451,7 +451,7 @@ struct dwc2_core_params { ...@@ -451,7 +451,7 @@ struct dwc2_core_params {
#define DWC2_CAP_PARAM_NO_HNP_SRP_CAPABLE 2 #define DWC2_CAP_PARAM_NO_HNP_SRP_CAPABLE 2
int otg_ver; int otg_ver;
int dma_enable; int host_dma;
int dma_desc_enable; int dma_desc_enable;
int dma_desc_fs_enable; int dma_desc_fs_enable;
int speed; int speed;
......
...@@ -79,7 +79,7 @@ static void dwc2_enable_common_interrupts(struct dwc2_hsotg *hsotg) ...@@ -79,7 +79,7 @@ static void dwc2_enable_common_interrupts(struct dwc2_hsotg *hsotg)
/* Enable the interrupts in the GINTMSK */ /* Enable the interrupts in the GINTMSK */
intmsk = GINTSTS_MODEMIS | GINTSTS_OTGINT; intmsk = GINTSTS_MODEMIS | GINTSTS_OTGINT;
if (hsotg->params.dma_enable <= 0) if (hsotg->params.host_dma <= 0)
intmsk |= GINTSTS_RXFLVL; intmsk |= GINTSTS_RXFLVL;
if (hsotg->params.external_id_pin_ctl <= 0) if (hsotg->params.external_id_pin_ctl <= 0)
intmsk |= GINTSTS_CONIDSTSCHNG; intmsk |= GINTSTS_CONIDSTSCHNG;
...@@ -285,11 +285,11 @@ static int dwc2_gahbcfg_init(struct dwc2_hsotg *hsotg) ...@@ -285,11 +285,11 @@ static int dwc2_gahbcfg_init(struct dwc2_hsotg *hsotg)
break; break;
} }
dev_dbg(hsotg->dev, "dma_enable:%d dma_desc_enable:%d\n", dev_dbg(hsotg->dev, "host_dma:%d dma_desc_enable:%d\n",
hsotg->params.dma_enable, hsotg->params.host_dma,
hsotg->params.dma_desc_enable); hsotg->params.dma_desc_enable);
if (hsotg->params.dma_enable > 0) { if (hsotg->params.host_dma > 0) {
if (hsotg->params.dma_desc_enable > 0) if (hsotg->params.dma_desc_enable > 0)
dev_dbg(hsotg->dev, "Using Descriptor DMA mode\n"); dev_dbg(hsotg->dev, "Using Descriptor DMA mode\n");
else else
...@@ -299,7 +299,7 @@ static int dwc2_gahbcfg_init(struct dwc2_hsotg *hsotg) ...@@ -299,7 +299,7 @@ static int dwc2_gahbcfg_init(struct dwc2_hsotg *hsotg)
hsotg->params.dma_desc_enable = 0; hsotg->params.dma_desc_enable = 0;
} }
if (hsotg->params.dma_enable > 0) if (hsotg->params.host_dma > 0)
ahbcfg |= GAHBCFG_DMA_EN; ahbcfg |= GAHBCFG_DMA_EN;
dwc2_writel(ahbcfg, hsotg->regs + GAHBCFG); dwc2_writel(ahbcfg, hsotg->regs + GAHBCFG);
...@@ -774,7 +774,7 @@ static void dwc2_hc_enable_ints(struct dwc2_hsotg *hsotg, ...@@ -774,7 +774,7 @@ static void dwc2_hc_enable_ints(struct dwc2_hsotg *hsotg,
{ {
u32 intmsk; u32 intmsk;
if (hsotg->params.dma_enable > 0) { if (hsotg->params.host_dma > 0) {
if (dbg_hc(chan)) if (dbg_hc(chan))
dev_vdbg(hsotg->dev, "DMA enabled\n"); dev_vdbg(hsotg->dev, "DMA enabled\n");
dwc2_hc_enable_dma_ints(hsotg, chan); dwc2_hc_enable_dma_ints(hsotg, chan);
...@@ -1004,7 +1004,7 @@ void dwc2_hc_halt(struct dwc2_hsotg *hsotg, struct dwc2_host_chan *chan, ...@@ -1004,7 +1004,7 @@ void dwc2_hc_halt(struct dwc2_hsotg *hsotg, struct dwc2_host_chan *chan,
} }
hcchar |= HCCHAR_CHDIS; hcchar |= HCCHAR_CHDIS;
if (hsotg->params.dma_enable <= 0) { if (hsotg->params.host_dma <= 0) {
if (dbg_hc(chan)) if (dbg_hc(chan))
dev_vdbg(hsotg->dev, "DMA not enabled\n"); dev_vdbg(hsotg->dev, "DMA not enabled\n");
hcchar |= HCCHAR_CHENA; hcchar |= HCCHAR_CHENA;
...@@ -1350,7 +1350,7 @@ static void dwc2_hc_start_transfer(struct dwc2_hsotg *hsotg, ...@@ -1350,7 +1350,7 @@ static void dwc2_hc_start_transfer(struct dwc2_hsotg *hsotg,
dev_vdbg(hsotg->dev, "%s()\n", __func__); dev_vdbg(hsotg->dev, "%s()\n", __func__);
if (chan->do_ping) { if (chan->do_ping) {
if (hsotg->params.dma_enable <= 0) { if (hsotg->params.host_dma <= 0) {
if (dbg_hc(chan)) if (dbg_hc(chan))
dev_vdbg(hsotg->dev, "ping, no DMA\n"); dev_vdbg(hsotg->dev, "ping, no DMA\n");
dwc2_hc_do_ping(hsotg, chan); dwc2_hc_do_ping(hsotg, chan);
...@@ -1478,7 +1478,7 @@ static void dwc2_hc_start_transfer(struct dwc2_hsotg *hsotg, ...@@ -1478,7 +1478,7 @@ static void dwc2_hc_start_transfer(struct dwc2_hsotg *hsotg,
TSIZ_SC_MC_PID_SHIFT); TSIZ_SC_MC_PID_SHIFT);
} }
if (hsotg->params.dma_enable > 0) { if (hsotg->params.host_dma > 0) {
dwc2_writel((u32)chan->xfer_dma, dwc2_writel((u32)chan->xfer_dma,
hsotg->regs + HCDMA(chan->hc_num)); hsotg->regs + HCDMA(chan->hc_num));
if (dbg_hc(chan)) if (dbg_hc(chan))
...@@ -1521,7 +1521,7 @@ static void dwc2_hc_start_transfer(struct dwc2_hsotg *hsotg, ...@@ -1521,7 +1521,7 @@ static void dwc2_hc_start_transfer(struct dwc2_hsotg *hsotg,
chan->xfer_started = 1; chan->xfer_started = 1;
chan->requests++; chan->requests++;
if (hsotg->params.dma_enable <= 0 && if (hsotg->params.host_dma <= 0 &&
!chan->ep_is_in && chan->xfer_len > 0) !chan->ep_is_in && chan->xfer_len > 0)
/* Load OUT packet into the appropriate Tx FIFO */ /* Load OUT packet into the appropriate Tx FIFO */
dwc2_hc_write_packet(hsotg, chan); dwc2_hc_write_packet(hsotg, chan);
...@@ -1804,7 +1804,7 @@ static void dwc2_hcd_cleanup_channels(struct dwc2_hsotg *hsotg) ...@@ -1804,7 +1804,7 @@ static void dwc2_hcd_cleanup_channels(struct dwc2_hsotg *hsotg)
u32 hcchar; u32 hcchar;
int i; int i;
if (hsotg->params.dma_enable <= 0) { if (hsotg->params.host_dma <= 0) {
/* Flush out any channel requests in slave mode */ /* Flush out any channel requests in slave mode */
for (i = 0; i < num_channels; i++) { for (i = 0; i < num_channels; i++) {
channel = hsotg->hc_ptr_array[i]; channel = hsotg->hc_ptr_array[i];
...@@ -2457,7 +2457,7 @@ static void dwc2_hc_init_xfer(struct dwc2_hsotg *hsotg, ...@@ -2457,7 +2457,7 @@ static void dwc2_hc_init_xfer(struct dwc2_hsotg *hsotg,
chan->do_ping = 0; chan->do_ping = 0;
chan->ep_is_in = 0; chan->ep_is_in = 0;
chan->data_pid_start = DWC2_HC_PID_SETUP; chan->data_pid_start = DWC2_HC_PID_SETUP;
if (hsotg->params.dma_enable > 0) if (hsotg->params.host_dma > 0)
chan->xfer_dma = urb->setup_dma; chan->xfer_dma = urb->setup_dma;
else else
chan->xfer_buf = urb->setup_packet; chan->xfer_buf = urb->setup_packet;
...@@ -2484,7 +2484,7 @@ static void dwc2_hc_init_xfer(struct dwc2_hsotg *hsotg, ...@@ -2484,7 +2484,7 @@ static void dwc2_hc_init_xfer(struct dwc2_hsotg *hsotg,
chan->do_ping = 0; chan->do_ping = 0;
chan->data_pid_start = DWC2_HC_PID_DATA1; chan->data_pid_start = DWC2_HC_PID_DATA1;
chan->xfer_len = 0; chan->xfer_len = 0;
if (hsotg->params.dma_enable > 0) if (hsotg->params.host_dma > 0)
chan->xfer_dma = hsotg->status_buf_dma; chan->xfer_dma = hsotg->status_buf_dma;
else else
chan->xfer_buf = hsotg->status_buf; chan->xfer_buf = hsotg->status_buf;
...@@ -2508,7 +2508,7 @@ static void dwc2_hc_init_xfer(struct dwc2_hsotg *hsotg, ...@@ -2508,7 +2508,7 @@ static void dwc2_hc_init_xfer(struct dwc2_hsotg *hsotg,
frame_desc = &urb->iso_descs[qtd->isoc_frame_index]; frame_desc = &urb->iso_descs[qtd->isoc_frame_index];
frame_desc->status = 0; frame_desc->status = 0;
if (hsotg->params.dma_enable > 0) { if (hsotg->params.host_dma > 0) {
chan->xfer_dma = urb->dma; chan->xfer_dma = urb->dma;
chan->xfer_dma += frame_desc->offset + chan->xfer_dma += frame_desc->offset +
qtd->isoc_split_offset; qtd->isoc_split_offset;
...@@ -2690,7 +2690,7 @@ static int dwc2_assign_and_init_hc(struct dwc2_hsotg *hsotg, struct dwc2_qh *qh) ...@@ -2690,7 +2690,7 @@ static int dwc2_assign_and_init_hc(struct dwc2_hsotg *hsotg, struct dwc2_qh *qh)
!dwc2_hcd_is_pipe_in(&urb->pipe_info)) !dwc2_hcd_is_pipe_in(&urb->pipe_info))
urb->actual_length = urb->length; urb->actual_length = urb->length;
if (hsotg->params.dma_enable > 0) if (hsotg->params.host_dma > 0)
chan->xfer_dma = urb->dma + urb->actual_length; chan->xfer_dma = urb->dma + urb->actual_length;
else else
chan->xfer_buf = (u8 *)urb->buf + urb->actual_length; chan->xfer_buf = (u8 *)urb->buf + urb->actual_length;
...@@ -2847,7 +2847,7 @@ static int dwc2_queue_transaction(struct dwc2_hsotg *hsotg, ...@@ -2847,7 +2847,7 @@ static int dwc2_queue_transaction(struct dwc2_hsotg *hsotg,
list_move_tail(&chan->split_order_list_entry, list_move_tail(&chan->split_order_list_entry,
&hsotg->split_order); &hsotg->split_order);
if (hsotg->params.dma_enable > 0) { if (hsotg->params.host_dma > 0) {
if (hsotg->params.dma_desc_enable > 0) { if (hsotg->params.dma_desc_enable > 0) {
if (!chan->xfer_started || if (!chan->xfer_started ||
chan->ep_type == USB_ENDPOINT_XFER_ISOC) { chan->ep_type == USB_ENDPOINT_XFER_ISOC) {
...@@ -2957,7 +2957,7 @@ static void dwc2_process_periodic_channels(struct dwc2_hsotg *hsotg) ...@@ -2957,7 +2957,7 @@ static void dwc2_process_periodic_channels(struct dwc2_hsotg *hsotg)
* The flag prevents any halts to get into the request queue in * The flag prevents any halts to get into the request queue in
* the middle of multiple high-bandwidth packets getting queued. * the middle of multiple high-bandwidth packets getting queued.
*/ */
if (hsotg->params.dma_enable <= 0 && if (hsotg->params.host_dma <= 0 &&
qh->channel->multi_count > 1) qh->channel->multi_count > 1)
hsotg->queuing_high_bandwidth = 1; hsotg->queuing_high_bandwidth = 1;
...@@ -2976,7 +2976,7 @@ static void dwc2_process_periodic_channels(struct dwc2_hsotg *hsotg) ...@@ -2976,7 +2976,7 @@ static void dwc2_process_periodic_channels(struct dwc2_hsotg *hsotg)
* controller automatically handles multiple packets for * controller automatically handles multiple packets for
* high-bandwidth transfers. * high-bandwidth transfers.
*/ */
if (hsotg->params.dma_enable > 0 || status == 0 || if (hsotg->params.host_dma > 0 || status == 0 ||
qh->channel->requests == qh->channel->multi_count) { qh->channel->requests == qh->channel->multi_count) {
qh_ptr = qh_ptr->next; qh_ptr = qh_ptr->next;
/* /*
...@@ -2993,7 +2993,7 @@ static void dwc2_process_periodic_channels(struct dwc2_hsotg *hsotg) ...@@ -2993,7 +2993,7 @@ static void dwc2_process_periodic_channels(struct dwc2_hsotg *hsotg)
exit: exit:
if (no_queue_space || no_fifo_space || if (no_queue_space || no_fifo_space ||
(hsotg->params.dma_enable <= 0 && (hsotg->params.host_dma <= 0 &&
!list_empty(&hsotg->periodic_sched_assigned))) { !list_empty(&hsotg->periodic_sched_assigned))) {
/* /*
* May need to queue more transactions as the request * May need to queue more transactions as the request
...@@ -3073,7 +3073,7 @@ static void dwc2_process_non_periodic_channels(struct dwc2_hsotg *hsotg) ...@@ -3073,7 +3073,7 @@ static void dwc2_process_non_periodic_channels(struct dwc2_hsotg *hsotg)
tx_status = dwc2_readl(hsotg->regs + GNPTXSTS); tx_status = dwc2_readl(hsotg->regs + GNPTXSTS);
qspcavail = (tx_status & TXSTS_QSPCAVAIL_MASK) >> qspcavail = (tx_status & TXSTS_QSPCAVAIL_MASK) >>
TXSTS_QSPCAVAIL_SHIFT; TXSTS_QSPCAVAIL_SHIFT;
if (hsotg->params.dma_enable <= 0 && qspcavail == 0) { if (hsotg->params.host_dma <= 0 && qspcavail == 0) {
no_queue_space = 1; no_queue_space = 1;
break; break;
} }
...@@ -3106,7 +3106,7 @@ static void dwc2_process_non_periodic_channels(struct dwc2_hsotg *hsotg) ...@@ -3106,7 +3106,7 @@ static void dwc2_process_non_periodic_channels(struct dwc2_hsotg *hsotg)
hsotg->non_periodic_qh_ptr->next; hsotg->non_periodic_qh_ptr->next;
} while (hsotg->non_periodic_qh_ptr != orig_qh_ptr); } while (hsotg->non_periodic_qh_ptr != orig_qh_ptr);
if (hsotg->params.dma_enable <= 0) { if (hsotg->params.host_dma <= 0) {
tx_status = dwc2_readl(hsotg->regs + GNPTXSTS); tx_status = dwc2_readl(hsotg->regs + GNPTXSTS);
qspcavail = (tx_status & TXSTS_QSPCAVAIL_MASK) >> qspcavail = (tx_status & TXSTS_QSPCAVAIL_MASK) >>
TXSTS_QSPCAVAIL_SHIFT; TXSTS_QSPCAVAIL_SHIFT;
...@@ -4919,7 +4919,7 @@ static void dwc2_hcd_free(struct dwc2_hsotg *hsotg) ...@@ -4919,7 +4919,7 @@ static void dwc2_hcd_free(struct dwc2_hsotg *hsotg)
} }
} }
if (hsotg->params.dma_enable > 0) { if (hsotg->params.host_dma > 0) {
if (hsotg->status_buf) { if (hsotg->status_buf) {
dma_free_coherent(hsotg->dev, DWC2_HCD_STATUS_BUF_SIZE, dma_free_coherent(hsotg->dev, DWC2_HCD_STATUS_BUF_SIZE,
hsotg->status_buf, hsotg->status_buf,
...@@ -4999,16 +4999,16 @@ int dwc2_hcd_init(struct dwc2_hsotg *hsotg, int irq) ...@@ -4999,16 +4999,16 @@ int dwc2_hcd_init(struct dwc2_hsotg *hsotg, int irq)
hsotg->last_frame_num = HFNUM_MAX_FRNUM; hsotg->last_frame_num = HFNUM_MAX_FRNUM;
/* Check if the bus driver or platform code has setup a dma_mask */ /* Check if the bus driver or platform code has setup a dma_mask */
if (hsotg->params.dma_enable > 0 && if (hsotg->params.host_dma > 0 &&
hsotg->dev->dma_mask == NULL) { hsotg->dev->dma_mask == NULL) {
dev_warn(hsotg->dev, dev_warn(hsotg->dev,
"dma_mask not set, disabling DMA\n"); "dma_mask not set, disabling DMA\n");
hsotg->params.dma_enable = 0; hsotg->params.host_dma = 0;
hsotg->params.dma_desc_enable = 0; hsotg->params.dma_desc_enable = 0;
} }
/* Set device flags indicating whether the HCD supports DMA */ /* Set device flags indicating whether the HCD supports DMA */
if (hsotg->params.dma_enable > 0) { if (hsotg->params.host_dma > 0) {
if (dma_set_mask(hsotg->dev, DMA_BIT_MASK(32)) < 0) if (dma_set_mask(hsotg->dev, DMA_BIT_MASK(32)) < 0)
dev_warn(hsotg->dev, "can't set DMA mask\n"); dev_warn(hsotg->dev, "can't set DMA mask\n");
if (dma_set_coherent_mask(hsotg->dev, DMA_BIT_MASK(32)) < 0) if (dma_set_coherent_mask(hsotg->dev, DMA_BIT_MASK(32)) < 0)
...@@ -5019,7 +5019,7 @@ int dwc2_hcd_init(struct dwc2_hsotg *hsotg, int irq) ...@@ -5019,7 +5019,7 @@ int dwc2_hcd_init(struct dwc2_hsotg *hsotg, int irq)
if (!hcd) if (!hcd)
goto error1; goto error1;
if (hsotg->params.dma_enable <= 0) if (hsotg->params.host_dma <= 0)
hcd->self.uses_dma = 0; hcd->self.uses_dma = 0;
hcd->has_tt = 1; hcd->has_tt = 1;
...@@ -5091,7 +5091,7 @@ int dwc2_hcd_init(struct dwc2_hsotg *hsotg, int irq) ...@@ -5091,7 +5091,7 @@ int dwc2_hcd_init(struct dwc2_hsotg *hsotg, int irq)
* done after usb_add_hcd since that function allocates the DMA buffer * done after usb_add_hcd since that function allocates the DMA buffer
* pool. * pool.
*/ */
if (hsotg->params.dma_enable > 0) if (hsotg->params.host_dma > 0)
hsotg->status_buf = dma_alloc_coherent(hsotg->dev, hsotg->status_buf = dma_alloc_coherent(hsotg->dev,
DWC2_HCD_STATUS_BUF_SIZE, DWC2_HCD_STATUS_BUF_SIZE,
&hsotg->status_buf_dma, GFP_KERNEL); &hsotg->status_buf_dma, GFP_KERNEL);
......
...@@ -604,7 +604,7 @@ static enum dwc2_halt_status dwc2_update_isoc_urb_state( ...@@ -604,7 +604,7 @@ static enum dwc2_halt_status dwc2_update_isoc_urb_state(
/* Skip whole frame */ /* Skip whole frame */
if (chan->qh->do_split && if (chan->qh->do_split &&
chan->ep_type == USB_ENDPOINT_XFER_ISOC && chan->ep_is_in && chan->ep_type == USB_ENDPOINT_XFER_ISOC && chan->ep_is_in &&
hsotg->params.dma_enable > 0) { hsotg->params.host_dma > 0) {
qtd->complete_split = 0; qtd->complete_split = 0;
qtd->isoc_split_offset = 0; qtd->isoc_split_offset = 0;
} }
...@@ -789,7 +789,7 @@ static void dwc2_halt_channel(struct dwc2_hsotg *hsotg, ...@@ -789,7 +789,7 @@ static void dwc2_halt_channel(struct dwc2_hsotg *hsotg,
if (dbg_hc(chan)) if (dbg_hc(chan))
dev_vdbg(hsotg->dev, "%s()\n", __func__); dev_vdbg(hsotg->dev, "%s()\n", __func__);
if (hsotg->params.dma_enable > 0) { if (hsotg->params.host_dma > 0) {
if (dbg_hc(chan)) if (dbg_hc(chan))
dev_vdbg(hsotg->dev, "DMA enabled\n"); dev_vdbg(hsotg->dev, "DMA enabled\n");
dwc2_release_channel(hsotg, chan, qtd, halt_status); dwc2_release_channel(hsotg, chan, qtd, halt_status);
...@@ -985,7 +985,7 @@ static void dwc2_hc_xfercomp_intr(struct dwc2_hsotg *hsotg, ...@@ -985,7 +985,7 @@ static void dwc2_hc_xfercomp_intr(struct dwc2_hsotg *hsotg,
/* Handle xfer complete on CSPLIT */ /* Handle xfer complete on CSPLIT */
if (chan->qh->do_split) { if (chan->qh->do_split) {
if (chan->ep_type == USB_ENDPOINT_XFER_ISOC && chan->ep_is_in && if (chan->ep_type == USB_ENDPOINT_XFER_ISOC && chan->ep_is_in &&
hsotg->params.dma_enable > 0) { hsotg->params.host_dma > 0) {
if (qtd->complete_split && if (qtd->complete_split &&
dwc2_xfercomp_isoc_split_in(hsotg, chan, chnum, dwc2_xfercomp_isoc_split_in(hsotg, chan, chnum,
qtd)) qtd))
...@@ -1207,7 +1207,7 @@ static void dwc2_hc_nak_intr(struct dwc2_hsotg *hsotg, ...@@ -1207,7 +1207,7 @@ static void dwc2_hc_nak_intr(struct dwc2_hsotg *hsotg,
switch (dwc2_hcd_get_pipe_type(&qtd->urb->pipe_info)) { switch (dwc2_hcd_get_pipe_type(&qtd->urb->pipe_info)) {
case USB_ENDPOINT_XFER_CONTROL: case USB_ENDPOINT_XFER_CONTROL:
case USB_ENDPOINT_XFER_BULK: case USB_ENDPOINT_XFER_BULK:
if (hsotg->params.dma_enable > 0 && chan->ep_is_in) { if (hsotg->params.host_dma > 0 && chan->ep_is_in) {
/* /*
* NAK interrupts are enabled on bulk/control IN * NAK interrupts are enabled on bulk/control IN
* transfers in DMA mode for the sole purpose of * transfers in DMA mode for the sole purpose of
...@@ -1353,7 +1353,7 @@ static void dwc2_hc_nyet_intr(struct dwc2_hsotg *hsotg, ...@@ -1353,7 +1353,7 @@ static void dwc2_hc_nyet_intr(struct dwc2_hsotg *hsotg,
*/ */
if (chan->do_split && chan->complete_split) { if (chan->do_split && chan->complete_split) {
if (chan->ep_is_in && chan->ep_type == USB_ENDPOINT_XFER_ISOC && if (chan->ep_is_in && chan->ep_type == USB_ENDPOINT_XFER_ISOC &&
hsotg->params.dma_enable > 0) { hsotg->params.host_dma > 0) {
qtd->complete_split = 0; qtd->complete_split = 0;
qtd->isoc_split_offset = 0; qtd->isoc_split_offset = 0;
qtd->isoc_frame_index++; qtd->isoc_frame_index++;
...@@ -1946,7 +1946,7 @@ static void dwc2_hc_chhltd_intr(struct dwc2_hsotg *hsotg, ...@@ -1946,7 +1946,7 @@ static void dwc2_hc_chhltd_intr(struct dwc2_hsotg *hsotg,
dev_vdbg(hsotg->dev, "--Host Channel %d Interrupt: Channel Halted--\n", dev_vdbg(hsotg->dev, "--Host Channel %d Interrupt: Channel Halted--\n",
chnum); chnum);
if (hsotg->params.dma_enable > 0) { if (hsotg->params.host_dma > 0) {
dwc2_hc_chhltd_intr_dma(hsotg, chan, chnum, qtd); dwc2_hc_chhltd_intr_dma(hsotg, chan, chnum, qtd);
} else { } else {
if (!dwc2_halt_status_ok(hsotg, chan, chnum, qtd)) if (!dwc2_halt_status_ok(hsotg, chan, chnum, qtd))
...@@ -2051,7 +2051,7 @@ static void dwc2_hc_n_intr(struct dwc2_hsotg *hsotg, int chnum) ...@@ -2051,7 +2051,7 @@ static void dwc2_hc_n_intr(struct dwc2_hsotg *hsotg, int chnum)
qtd = list_first_entry(&chan->qh->qtd_list, struct dwc2_qtd, qtd = list_first_entry(&chan->qh->qtd_list, struct dwc2_qtd,
qtd_list_entry); qtd_list_entry);
if (hsotg->params.dma_enable <= 0) { if (hsotg->params.host_dma <= 0) {
if ((hcint & HCINTMSK_CHHLTD) && hcint != HCINTMSK_CHHLTD) if ((hcint & HCINTMSK_CHHLTD) && hcint != HCINTMSK_CHHLTD)
hcint &= ~HCINTMSK_CHHLTD; hcint &= ~HCINTMSK_CHHLTD;
} }
......
...@@ -41,7 +41,7 @@ ...@@ -41,7 +41,7 @@
static const struct dwc2_core_params params_hi6220 = { static const struct dwc2_core_params params_hi6220 = {
.otg_cap = 2, /* No HNP/SRP capable */ .otg_cap = 2, /* No HNP/SRP capable */
.otg_ver = 0, /* 1.3 */ .otg_ver = 0, /* 1.3 */
.dma_enable = 1, .host_dma = 1,
.dma_desc_enable = 0, .dma_desc_enable = 0,
.dma_desc_fs_enable = 0, .dma_desc_fs_enable = 0,
.speed = 0, /* High Speed */ .speed = 0, /* High Speed */
...@@ -73,7 +73,7 @@ static const struct dwc2_core_params params_hi6220 = { ...@@ -73,7 +73,7 @@ static const struct dwc2_core_params params_hi6220 = {
static const struct dwc2_core_params params_bcm2835 = { static const struct dwc2_core_params params_bcm2835 = {
.otg_cap = 0, /* HNP/SRP capable */ .otg_cap = 0, /* HNP/SRP capable */
.otg_ver = 0, /* 1.3 */ .otg_ver = 0, /* 1.3 */
.dma_enable = 1, .host_dma = 1,
.dma_desc_enable = 0, .dma_desc_enable = 0,
.dma_desc_fs_enable = 0, .dma_desc_fs_enable = 0,
.speed = 0, /* High Speed */ .speed = 0, /* High Speed */
...@@ -104,7 +104,7 @@ static const struct dwc2_core_params params_bcm2835 = { ...@@ -104,7 +104,7 @@ static const struct dwc2_core_params params_bcm2835 = {
static const struct dwc2_core_params params_rk3066 = { static const struct dwc2_core_params params_rk3066 = {
.otg_cap = 2, /* non-HNP/non-SRP */ .otg_cap = 2, /* non-HNP/non-SRP */
.otg_ver = -1, .otg_ver = -1,
.dma_enable = -1, .host_dma = -1,
.dma_desc_enable = 0, .dma_desc_enable = 0,
.dma_desc_fs_enable = 0, .dma_desc_fs_enable = 0,
.speed = -1, .speed = -1,
...@@ -136,7 +136,7 @@ static const struct dwc2_core_params params_rk3066 = { ...@@ -136,7 +136,7 @@ static const struct dwc2_core_params params_rk3066 = {
static const struct dwc2_core_params params_ltq = { static const struct dwc2_core_params params_ltq = {
.otg_cap = 2, /* non-HNP/non-SRP */ .otg_cap = 2, /* non-HNP/non-SRP */
.otg_ver = -1, .otg_ver = -1,
.dma_enable = -1, .host_dma = -1,
.dma_desc_enable = -1, .dma_desc_enable = -1,
.dma_desc_fs_enable = -1, .dma_desc_fs_enable = -1,
.speed = -1, .speed = -1,
...@@ -168,7 +168,7 @@ static const struct dwc2_core_params params_ltq = { ...@@ -168,7 +168,7 @@ static const struct dwc2_core_params params_ltq = {
static const struct dwc2_core_params params_amlogic = { static const struct dwc2_core_params params_amlogic = {
.otg_cap = DWC2_CAP_PARAM_NO_HNP_SRP_CAPABLE, .otg_cap = DWC2_CAP_PARAM_NO_HNP_SRP_CAPABLE,
.otg_ver = -1, .otg_ver = -1,
.dma_enable = 1, .host_dma = 1,
.dma_desc_enable = 0, .dma_desc_enable = 0,
.dma_desc_fs_enable = 0, .dma_desc_fs_enable = 0,
.speed = DWC2_SPEED_PARAM_HIGH, .speed = DWC2_SPEED_PARAM_HIGH,
...@@ -200,7 +200,7 @@ static const struct dwc2_core_params params_amlogic = { ...@@ -200,7 +200,7 @@ static const struct dwc2_core_params params_amlogic = {
static const struct dwc2_core_params params_default = { static const struct dwc2_core_params params_default = {
.otg_cap = -1, .otg_cap = -1,
.otg_ver = -1, .otg_ver = -1,
.dma_enable = -1, .host_dma = -1,
/* /*
* Disable descriptor dma mode by default as the HW can support * Disable descriptor dma mode by default as the HW can support
...@@ -486,7 +486,7 @@ static void dwc2_set_param_otg_cap(struct dwc2_hsotg *hsotg, int val) ...@@ -486,7 +486,7 @@ static void dwc2_set_param_otg_cap(struct dwc2_hsotg *hsotg, int val)
hsotg->params.otg_cap = val; hsotg->params.otg_cap = val;
} }
static void dwc2_set_param_dma_enable(struct dwc2_hsotg *hsotg, int val) static void dwc2_set_param_host_dma(struct dwc2_hsotg *hsotg, int val)
{ {
int valid = 1; int valid = 1;
...@@ -498,20 +498,20 @@ static void dwc2_set_param_dma_enable(struct dwc2_hsotg *hsotg, int val) ...@@ -498,20 +498,20 @@ static void dwc2_set_param_dma_enable(struct dwc2_hsotg *hsotg, int val)
if (!valid) { if (!valid) {
if (val >= 0) if (val >= 0)
dev_err(hsotg->dev, dev_err(hsotg->dev,
"%d invalid for dma_enable parameter. Check HW configuration.\n", "%d invalid for host_dma parameter. Check HW configuration.\n",
val); val);
val = hsotg->hw_params.arch != GHWCFG2_SLAVE_ONLY_ARCH; val = hsotg->hw_params.arch != GHWCFG2_SLAVE_ONLY_ARCH;
dev_dbg(hsotg->dev, "Setting dma_enable to %d\n", val); dev_dbg(hsotg->dev, "Setting host_dma to %d\n", val);
} }
hsotg->params.dma_enable = val; hsotg->params.host_dma = val;
} }
static void dwc2_set_param_dma_desc_enable(struct dwc2_hsotg *hsotg, int val) static void dwc2_set_param_dma_desc_enable(struct dwc2_hsotg *hsotg, int val)
{ {
int valid = 1; int valid = 1;
if (val > 0 && (hsotg->params.dma_enable <= 0 || if (val > 0 && (hsotg->params.host_dma <= 0 ||
!hsotg->hw_params.dma_desc_enable)) !hsotg->hw_params.dma_desc_enable))
valid = 0; valid = 0;
if (val < 0) if (val < 0)
...@@ -522,7 +522,7 @@ static void dwc2_set_param_dma_desc_enable(struct dwc2_hsotg *hsotg, int val) ...@@ -522,7 +522,7 @@ static void dwc2_set_param_dma_desc_enable(struct dwc2_hsotg *hsotg, int val)
dev_err(hsotg->dev, dev_err(hsotg->dev,
"%d invalid for dma_desc_enable parameter. Check HW configuration.\n", "%d invalid for dma_desc_enable parameter. Check HW configuration.\n",
val); val);
val = (hsotg->params.dma_enable > 0 && val = (hsotg->params.host_dma > 0 &&
hsotg->hw_params.dma_desc_enable); hsotg->hw_params.dma_desc_enable);
dev_dbg(hsotg->dev, "Setting dma_desc_enable to %d\n", val); dev_dbg(hsotg->dev, "Setting dma_desc_enable to %d\n", val);
} }
...@@ -534,7 +534,7 @@ static void dwc2_set_param_dma_desc_fs_enable(struct dwc2_hsotg *hsotg, int val) ...@@ -534,7 +534,7 @@ static void dwc2_set_param_dma_desc_fs_enable(struct dwc2_hsotg *hsotg, int val)
{ {
int valid = 1; int valid = 1;
if (val > 0 && (hsotg->params.dma_enable <= 0 || if (val > 0 && (hsotg->params.host_dma <= 0 ||
!hsotg->hw_params.dma_desc_enable)) !hsotg->hw_params.dma_desc_enable))
valid = 0; valid = 0;
if (val < 0) if (val < 0)
...@@ -545,7 +545,7 @@ static void dwc2_set_param_dma_desc_fs_enable(struct dwc2_hsotg *hsotg, int val) ...@@ -545,7 +545,7 @@ static void dwc2_set_param_dma_desc_fs_enable(struct dwc2_hsotg *hsotg, int val)
dev_err(hsotg->dev, dev_err(hsotg->dev,
"%d invalid for dma_desc_fs_enable parameter. Check HW configuration.\n", "%d invalid for dma_desc_fs_enable parameter. Check HW configuration.\n",
val); val);
val = (hsotg->params.dma_enable > 0 && val = (hsotg->params.host_dma > 0 &&
hsotg->hw_params.dma_desc_enable); hsotg->hw_params.dma_desc_enable);
} }
...@@ -1126,7 +1126,7 @@ static void dwc2_set_parameters(struct dwc2_hsotg *hsotg, ...@@ -1126,7 +1126,7 @@ static void dwc2_set_parameters(struct dwc2_hsotg *hsotg,
struct dwc2_core_params *p = &hsotg->params; struct dwc2_core_params *p = &hsotg->params;
dwc2_set_param_otg_cap(hsotg, params->otg_cap); dwc2_set_param_otg_cap(hsotg, params->otg_cap);
dwc2_set_param_dma_enable(hsotg, params->dma_enable); dwc2_set_param_host_dma(hsotg, params->host_dma);
dwc2_set_param_dma_desc_enable(hsotg, params->dma_desc_enable); dwc2_set_param_dma_desc_enable(hsotg, params->dma_desc_enable);
dwc2_set_param_dma_desc_fs_enable(hsotg, params->dma_desc_fs_enable); dwc2_set_param_dma_desc_fs_enable(hsotg, params->dma_desc_fs_enable);
dwc2_set_param_host_support_fs_ls_low_power(hsotg, dwc2_set_param_host_support_fs_ls_low_power(hsotg,
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册