Lines Matching +full:disable +full:- +full:hibernation +full:- +full:mode
1 // SPDX-License-Identifier: (GPL-2.0+ OR BSD-3-Clause)
3 * hcd.c - DesignWare HS OTG Controller host-mode routines
5 * Copyright (C) 2004-2013 Synopsys, Inc.
17 #include <linux/dma-mapping.h>
37 * dwc2_enable_common_interrupts() - Initializes the commmon interrupts,
55 if (!hsotg->params.host_dma) in dwc2_enable_common_interrupts()
57 if (!hsotg->params.external_id_pin_ctl) in dwc2_enable_common_interrupts()
63 if (dwc2_is_device_mode(hsotg) && hsotg->params.lpm) in dwc2_enable_common_interrupts()
73 switch (hsotg->hw_params.arch) { in dwc2_gahbcfg_init()
75 dev_err(hsotg->dev, "External DMA Mode not supported\n"); in dwc2_gahbcfg_init()
76 return -EINVAL; in dwc2_gahbcfg_init()
79 dev_dbg(hsotg->dev, "Internal DMA Mode\n"); in dwc2_gahbcfg_init()
80 if (hsotg->params.ahbcfg != -1) { in dwc2_gahbcfg_init()
82 ahbcfg |= hsotg->params.ahbcfg & in dwc2_gahbcfg_init()
89 dev_dbg(hsotg->dev, "Slave Only Mode\n"); in dwc2_gahbcfg_init()
93 if (hsotg->params.host_dma) in dwc2_gahbcfg_init()
96 hsotg->params.dma_desc_enable = false; in dwc2_gahbcfg_init()
110 switch (hsotg->hw_params.op_mode) { in dwc2_gusbcfg_init()
112 if (hsotg->params.otg_caps.hnp_support && in dwc2_gusbcfg_init()
113 hsotg->params.otg_caps.srp_support) in dwc2_gusbcfg_init()
120 if (hsotg->params.otg_caps.srp_support) in dwc2_gusbcfg_init()
136 if (hsotg->vbus_supply) in dwc2_vbus_supply_init()
137 return regulator_enable(hsotg->vbus_supply); in dwc2_vbus_supply_init()
144 if (hsotg->vbus_supply) in dwc2_vbus_supply_exit()
145 return regulator_disable(hsotg->vbus_supply); in dwc2_vbus_supply_exit()
151 * dwc2_enable_host_interrupts() - Enables the Host mode interrupts
159 dev_dbg(hsotg->dev, "%s()\n", __func__); in dwc2_enable_host_interrupts()
161 /* Disable all interrupts */ in dwc2_enable_host_interrupts()
168 /* Enable host mode interrupts without disturbing common interrupts */ in dwc2_enable_host_interrupts()
175 * dwc2_disable_host_interrupts() - Disables the Host Mode interrupts
183 /* Disable host mode interrupts without disturbing common interrupts */ in dwc2_disable_host_interrupts()
190 * dwc2_calculate_dynamic_fifo() - Calculates the default fifo size
198 struct dwc2_core_params *params = &hsotg->params; in dwc2_calculate_dynamic_fifo()
199 struct dwc2_hw_params *hw = &hsotg->hw_params; in dwc2_calculate_dynamic_fifo()
202 total_fifo_size = hw->total_fifo_size; in dwc2_calculate_dynamic_fifo()
203 rxfsiz = params->host_rx_fifo_size; in dwc2_calculate_dynamic_fifo()
204 nptxfsiz = params->host_nperio_tx_fifo_size; in dwc2_calculate_dynamic_fifo()
205 ptxfsiz = params->host_perio_tx_fifo_size; in dwc2_calculate_dynamic_fifo()
211 * non-periodic as 512. in dwc2_calculate_dynamic_fifo()
215 * For Buffer DMA mode/Scatter Gather DMA mode in dwc2_calculate_dynamic_fifo()
220 rxfsiz = 516 + hw->host_channels; in dwc2_calculate_dynamic_fifo()
223 * min non-periodic tx fifo depth in dwc2_calculate_dynamic_fifo()
224 * 2 * (largest non-periodic USB packet used / 4) in dwc2_calculate_dynamic_fifo()
236 params->host_rx_fifo_size = rxfsiz; in dwc2_calculate_dynamic_fifo()
237 params->host_nperio_tx_fifo_size = nptxfsiz; in dwc2_calculate_dynamic_fifo()
238 params->host_perio_tx_fifo_size = ptxfsiz; in dwc2_calculate_dynamic_fifo()
252 dev_err(hsotg->dev, "invalid fifo sizes\n"); in dwc2_calculate_dynamic_fifo()
257 struct dwc2_core_params *params = &hsotg->params; in dwc2_config_fifos()
260 if (!params->enable_dynamic_fifo) in dwc2_config_fifos()
267 dev_dbg(hsotg->dev, "initial grxfsiz=%08x\n", grxfsiz); in dwc2_config_fifos()
269 grxfsiz |= params->host_rx_fifo_size << in dwc2_config_fifos()
272 dev_dbg(hsotg->dev, "new grxfsiz=%08x\n", in dwc2_config_fifos()
275 /* Non-periodic Tx FIFO */ in dwc2_config_fifos()
276 dev_dbg(hsotg->dev, "initial gnptxfsiz=%08x\n", in dwc2_config_fifos()
278 nptxfsiz = params->host_nperio_tx_fifo_size << in dwc2_config_fifos()
280 nptxfsiz |= params->host_rx_fifo_size << in dwc2_config_fifos()
283 dev_dbg(hsotg->dev, "new gnptxfsiz=%08x\n", in dwc2_config_fifos()
287 dev_dbg(hsotg->dev, "initial hptxfsiz=%08x\n", in dwc2_config_fifos()
289 hptxfsiz = params->host_perio_tx_fifo_size << in dwc2_config_fifos()
291 hptxfsiz |= (params->host_rx_fifo_size + in dwc2_config_fifos()
292 params->host_nperio_tx_fifo_size) << in dwc2_config_fifos()
295 dev_dbg(hsotg->dev, "new hptxfsiz=%08x\n", in dwc2_config_fifos()
298 if (hsotg->params.en_multiple_tx_fifo && in dwc2_config_fifos()
299 hsotg->hw_params.snpsid >= DWC2_CORE_REV_2_91a) { in dwc2_config_fifos()
302 * Global DFIFOCFG calculation for Host mode - in dwc2_config_fifos()
307 dfifocfg |= (params->host_rx_fifo_size + in dwc2_config_fifos()
308 params->host_nperio_tx_fifo_size + in dwc2_config_fifos()
309 params->host_perio_tx_fifo_size) << in dwc2_config_fifos()
317 * dwc2_calc_frame_interval() - Calculates the correct frame Interval value for
338 if ((usbcfg & GUSBCFG_PHYSEL) && hsotg->hw_params.fs_phy_type == in dwc2_calc_frame_interval()
351 hsotg->hw_params.fs_phy_type == GHWCFG2_FS_PHY_TYPE_SHARED_UTMI) in dwc2_calc_frame_interval()
354 hsotg->hw_params.fs_phy_type == GHWCFG2_FS_PHY_TYPE_DEDICATED) in dwc2_calc_frame_interval()
359 return 125 * clock - 1; in dwc2_calc_frame_interval()
362 return 1000 * clock - 1; in dwc2_calc_frame_interval()
366 * dwc2_read_packet() - Reads a packet from the Rx FIFO into the destination
385 dev_vdbg(hsotg->dev, "%s(%p,%p,%d)\n", __func__, hsotg, dest, bytes); in dwc2_read_packet()
392 * dwc2_dump_channel_info() - Prints the state of a host channel
406 int num_channels = hsotg->params.host_channels; in dwc2_dump_channel_info()
417 hcchar = dwc2_readl(hsotg, HCCHAR(chan->hc_num)); in dwc2_dump_channel_info()
418 hcsplt = dwc2_readl(hsotg, HCSPLT(chan->hc_num)); in dwc2_dump_channel_info()
419 hctsiz = dwc2_readl(hsotg, HCTSIZ(chan->hc_num)); in dwc2_dump_channel_info()
420 hc_dma = dwc2_readl(hsotg, HCDMA(chan->hc_num)); in dwc2_dump_channel_info()
422 dev_dbg(hsotg->dev, " Assigned to channel %p:\n", chan); in dwc2_dump_channel_info()
423 dev_dbg(hsotg->dev, " hcchar 0x%08x, hcsplt 0x%08x\n", in dwc2_dump_channel_info()
425 dev_dbg(hsotg->dev, " hctsiz 0x%08x, hc_dma 0x%08x\n", in dwc2_dump_channel_info()
427 dev_dbg(hsotg->dev, " dev_addr: %d, ep_num: %d, ep_is_in: %d\n", in dwc2_dump_channel_info()
428 chan->dev_addr, chan->ep_num, chan->ep_is_in); in dwc2_dump_channel_info()
429 dev_dbg(hsotg->dev, " ep_type: %d\n", chan->ep_type); in dwc2_dump_channel_info()
430 dev_dbg(hsotg->dev, " max_packet: %d\n", chan->max_packet); in dwc2_dump_channel_info()
431 dev_dbg(hsotg->dev, " data_pid_start: %d\n", chan->data_pid_start); in dwc2_dump_channel_info()
432 dev_dbg(hsotg->dev, " xfer_started: %d\n", chan->xfer_started); in dwc2_dump_channel_info()
433 dev_dbg(hsotg->dev, " halt_status: %d\n", chan->halt_status); in dwc2_dump_channel_info()
434 dev_dbg(hsotg->dev, " xfer_buf: %p\n", chan->xfer_buf); in dwc2_dump_channel_info()
435 dev_dbg(hsotg->dev, " xfer_dma: %08lx\n", in dwc2_dump_channel_info()
436 (unsigned long)chan->xfer_dma); in dwc2_dump_channel_info()
437 dev_dbg(hsotg->dev, " xfer_len: %d\n", chan->xfer_len); in dwc2_dump_channel_info()
438 dev_dbg(hsotg->dev, " qh: %p\n", chan->qh); in dwc2_dump_channel_info()
439 dev_dbg(hsotg->dev, " NP inactive sched:\n"); in dwc2_dump_channel_info()
440 list_for_each_entry(qh, &hsotg->non_periodic_sched_inactive, in dwc2_dump_channel_info()
442 dev_dbg(hsotg->dev, " %p\n", qh); in dwc2_dump_channel_info()
443 dev_dbg(hsotg->dev, " NP waiting sched:\n"); in dwc2_dump_channel_info()
444 list_for_each_entry(qh, &hsotg->non_periodic_sched_waiting, in dwc2_dump_channel_info()
446 dev_dbg(hsotg->dev, " %p\n", qh); in dwc2_dump_channel_info()
447 dev_dbg(hsotg->dev, " NP active sched:\n"); in dwc2_dump_channel_info()
448 list_for_each_entry(qh, &hsotg->non_periodic_sched_active, in dwc2_dump_channel_info()
450 dev_dbg(hsotg->dev, " %p\n", qh); in dwc2_dump_channel_info()
451 dev_dbg(hsotg->dev, " Channels:\n"); in dwc2_dump_channel_info()
453 struct dwc2_host_chan *chan = hsotg->hc_ptr_array[i]; in dwc2_dump_channel_info()
455 dev_dbg(hsotg->dev, " %2d: %p\n", i, chan); in dwc2_dump_channel_info()
466 hcd->self.is_b_host = dwc2_hcd_is_b_host(hsotg); in dwc2_host_start()
474 hcd->self.is_b_host = 0; in dwc2_host_disconnect()
482 if (urb->dev->tt) in dwc2_host_hub_info()
483 *hub_addr = urb->dev->tt->hub->devnum; in dwc2_host_hub_info()
486 *hub_port = urb->dev->ttport; in dwc2_host_hub_info()
500 switch (chan->ep_type) { in dwc2_hc_enable_slave_ints()
503 dev_vdbg(hsotg->dev, "control/bulk\n"); in dwc2_hc_enable_slave_ints()
508 if (chan->ep_is_in) { in dwc2_hc_enable_slave_ints()
513 if (chan->do_ping) in dwc2_hc_enable_slave_ints()
517 if (chan->do_split) { in dwc2_hc_enable_slave_ints()
519 if (chan->complete_split) in dwc2_hc_enable_slave_ints()
525 if (chan->error_state) in dwc2_hc_enable_slave_ints()
531 dev_vdbg(hsotg->dev, "intr\n"); in dwc2_hc_enable_slave_ints()
539 if (chan->ep_is_in) in dwc2_hc_enable_slave_ints()
541 if (chan->error_state) in dwc2_hc_enable_slave_ints()
543 if (chan->do_split) { in dwc2_hc_enable_slave_ints()
544 if (chan->complete_split) in dwc2_hc_enable_slave_ints()
553 dev_vdbg(hsotg->dev, "isoc\n"); in dwc2_hc_enable_slave_ints()
558 if (chan->ep_is_in) { in dwc2_hc_enable_slave_ints()
564 dev_err(hsotg->dev, "## Unknown EP type ##\n"); in dwc2_hc_enable_slave_ints()
568 dwc2_writel(hsotg, hcintmsk, HCINTMSK(chan->hc_num)); in dwc2_hc_enable_slave_ints()
570 dev_vdbg(hsotg->dev, "set HCINTMSK to %08x\n", hcintmsk); in dwc2_hc_enable_slave_ints()
579 * For Descriptor DMA mode core halts the channel on AHB error. in dwc2_hc_enable_dma_ints()
582 if (!hsotg->params.dma_desc_enable) { in dwc2_hc_enable_dma_ints()
584 dev_vdbg(hsotg->dev, "desc DMA disabled\n"); in dwc2_hc_enable_dma_ints()
588 dev_vdbg(hsotg->dev, "desc DMA enabled\n"); in dwc2_hc_enable_dma_ints()
589 if (chan->ep_type == USB_ENDPOINT_XFER_ISOC) in dwc2_hc_enable_dma_ints()
593 if (chan->error_state && !chan->do_split && in dwc2_hc_enable_dma_ints()
594 chan->ep_type != USB_ENDPOINT_XFER_ISOC) { in dwc2_hc_enable_dma_ints()
596 dev_vdbg(hsotg->dev, "setting ACK\n"); in dwc2_hc_enable_dma_ints()
598 if (chan->ep_is_in) { in dwc2_hc_enable_dma_ints()
600 if (chan->ep_type != USB_ENDPOINT_XFER_INT) in dwc2_hc_enable_dma_ints()
605 dwc2_writel(hsotg, hcintmsk, HCINTMSK(chan->hc_num)); in dwc2_hc_enable_dma_ints()
607 dev_vdbg(hsotg->dev, "set HCINTMSK to %08x\n", hcintmsk); in dwc2_hc_enable_dma_ints()
615 if (hsotg->params.host_dma) { in dwc2_hc_enable_ints()
617 dev_vdbg(hsotg->dev, "DMA enabled\n"); in dwc2_hc_enable_ints()
621 dev_vdbg(hsotg->dev, "DMA disabled\n"); in dwc2_hc_enable_ints()
627 intmsk |= 1 << chan->hc_num; in dwc2_hc_enable_ints()
630 dev_vdbg(hsotg->dev, "set HAINTMSK to %08x\n", intmsk); in dwc2_hc_enable_ints()
637 dev_vdbg(hsotg->dev, "set GINTMSK to %08x\n", intmsk); in dwc2_hc_enable_ints()
641 * dwc2_hc_init() - Prepares a host channel for transferring packets to/from
653 u8 hc_num = chan->hc_num; in dwc2_hc_init()
659 dev_vdbg(hsotg->dev, "%s()\n", __func__); in dwc2_hc_init()
673 hcchar = chan->dev_addr << HCCHAR_DEVADDR_SHIFT & HCCHAR_DEVADDR_MASK; in dwc2_hc_init()
674 hcchar |= chan->ep_num << HCCHAR_EPNUM_SHIFT & HCCHAR_EPNUM_MASK; in dwc2_hc_init()
675 if (chan->ep_is_in) in dwc2_hc_init()
677 if (chan->speed == USB_SPEED_LOW) in dwc2_hc_init()
679 hcchar |= chan->ep_type << HCCHAR_EPTYPE_SHIFT & HCCHAR_EPTYPE_MASK; in dwc2_hc_init()
680 hcchar |= chan->max_packet << HCCHAR_MPS_SHIFT & HCCHAR_MPS_MASK; in dwc2_hc_init()
683 dev_vdbg(hsotg->dev, "set HCCHAR(%d) to %08x\n", in dwc2_hc_init()
686 dev_vdbg(hsotg->dev, "%s: Channel %d\n", in dwc2_hc_init()
688 dev_vdbg(hsotg->dev, " Dev Addr: %d\n", in dwc2_hc_init()
689 chan->dev_addr); in dwc2_hc_init()
690 dev_vdbg(hsotg->dev, " Ep Num: %d\n", in dwc2_hc_init()
691 chan->ep_num); in dwc2_hc_init()
692 dev_vdbg(hsotg->dev, " Is In: %d\n", in dwc2_hc_init()
693 chan->ep_is_in); in dwc2_hc_init()
694 dev_vdbg(hsotg->dev, " Is Low Speed: %d\n", in dwc2_hc_init()
695 chan->speed == USB_SPEED_LOW); in dwc2_hc_init()
696 dev_vdbg(hsotg->dev, " Ep Type: %d\n", in dwc2_hc_init()
697 chan->ep_type); in dwc2_hc_init()
698 dev_vdbg(hsotg->dev, " Max Pkt: %d\n", in dwc2_hc_init()
699 chan->max_packet); in dwc2_hc_init()
703 if (chan->do_split) { in dwc2_hc_init()
705 dev_vdbg(hsotg->dev, in dwc2_hc_init()
706 "Programming HC %d with split --> %s\n", in dwc2_hc_init()
708 chan->complete_split ? "CSPLIT" : "SSPLIT"); in dwc2_hc_init()
709 if (chan->complete_split) in dwc2_hc_init()
711 hcsplt |= chan->xact_pos << HCSPLT_XACTPOS_SHIFT & in dwc2_hc_init()
713 hcsplt |= chan->hub_addr << HCSPLT_HUBADDR_SHIFT & in dwc2_hc_init()
715 hcsplt |= chan->hub_port << HCSPLT_PRTADDR_SHIFT & in dwc2_hc_init()
718 dev_vdbg(hsotg->dev, " comp split %d\n", in dwc2_hc_init()
719 chan->complete_split); in dwc2_hc_init()
720 dev_vdbg(hsotg->dev, " xact pos %d\n", in dwc2_hc_init()
721 chan->xact_pos); in dwc2_hc_init()
722 dev_vdbg(hsotg->dev, " hub addr %d\n", in dwc2_hc_init()
723 chan->hub_addr); in dwc2_hc_init()
724 dev_vdbg(hsotg->dev, " hub port %d\n", in dwc2_hc_init()
725 chan->hub_port); in dwc2_hc_init()
726 dev_vdbg(hsotg->dev, " is_in %d\n", in dwc2_hc_init()
727 chan->ep_is_in); in dwc2_hc_init()
728 dev_vdbg(hsotg->dev, " Max Pkt %d\n", in dwc2_hc_init()
729 chan->max_packet); in dwc2_hc_init()
730 dev_vdbg(hsotg->dev, " xferlen %d\n", in dwc2_hc_init()
731 chan->xfer_len); in dwc2_hc_init()
739 * dwc2_hc_halt() - Attempts to halt a host channel
745 * This function should only be called in Slave mode or to abort a transfer in
746 * either Slave mode or DMA mode. Under normal circumstances in DMA mode, the
750 * In slave mode, checks for a free request queue entry, then sets the Channel
751 * Enable and Channel Disable bits of the Host Channel Characteristics
753 * request queue entry, sets only the Channel Disable bit of the HCCHARn
758 * In DMA mode, always sets the Channel Enable and Channel Disable bits of the
772 dev_vdbg(hsotg->dev, "%s()\n", __func__); in dwc2_hc_halt()
775 * In buffer DMA or external DMA mode channel can't be halted in dwc2_hc_halt()
776 * for non-split periodic channels. At the end of the next in dwc2_hc_halt()
780 if ((hsotg->params.g_dma && !hsotg->params.g_dma_desc) || in dwc2_hc_halt()
781 hsotg->hw_params.arch == GHWCFG2_EXT_DMA_ARCH) { in dwc2_hc_halt()
782 if (!chan->do_split && in dwc2_hc_halt()
783 (chan->ep_type == USB_ENDPOINT_XFER_ISOC || in dwc2_hc_halt()
784 chan->ep_type == USB_ENDPOINT_XFER_INT)) { in dwc2_hc_halt()
785 dev_err(hsotg->dev, "%s() Channel can't be halted\n", in dwc2_hc_halt()
792 dev_err(hsotg->dev, "!!! halt_status = %d !!!\n", halt_status); in dwc2_hc_halt()
797 * Disable all channel interrupts except Ch Halted. The QTD in dwc2_hc_halt()
804 dev_vdbg(hsotg->dev, "dequeue/error\n"); in dwc2_hc_halt()
805 dwc2_writel(hsotg, hcintmsk, HCINTMSK(chan->hc_num)); in dwc2_hc_halt()
812 dwc2_writel(hsotg, ~hcintmsk, HCINT(chan->hc_num)); in dwc2_hc_halt()
819 chan->halt_status = halt_status; in dwc2_hc_halt()
821 hcchar = dwc2_readl(hsotg, HCCHAR(chan->hc_num)); in dwc2_hc_halt()
825 * started yet. In DMA mode, the transfer may halt if in dwc2_hc_halt()
828 * the channel again. In either Slave or DMA mode, in dwc2_hc_halt()
837 if (chan->halt_pending) { in dwc2_hc_halt()
843 dev_vdbg(hsotg->dev, in dwc2_hc_halt()
844 "*** %s: Channel %d, chan->halt_pending already set ***\n", in dwc2_hc_halt()
845 __func__, chan->hc_num); in dwc2_hc_halt()
849 hcchar = dwc2_readl(hsotg, HCCHAR(chan->hc_num)); in dwc2_hc_halt()
853 if (!hsotg->params.dma_desc_enable) { in dwc2_hc_halt()
855 dev_vdbg(hsotg->dev, "desc DMA disabled\n"); in dwc2_hc_halt()
859 dev_dbg(hsotg->dev, "desc DMA enabled\n"); in dwc2_hc_halt()
863 if (!hsotg->params.host_dma) { in dwc2_hc_halt()
865 dev_vdbg(hsotg->dev, "DMA not enabled\n"); in dwc2_hc_halt()
869 if (chan->ep_type == USB_ENDPOINT_XFER_CONTROL || in dwc2_hc_halt()
870 chan->ep_type == USB_ENDPOINT_XFER_BULK) { in dwc2_hc_halt()
871 dev_vdbg(hsotg->dev, "control/bulk\n"); in dwc2_hc_halt()
874 dev_vdbg(hsotg->dev, "Disabling channel\n"); in dwc2_hc_halt()
879 dev_vdbg(hsotg->dev, "isoc/intr\n"); in dwc2_hc_halt()
882 hsotg->queuing_high_bandwidth) { in dwc2_hc_halt()
884 dev_vdbg(hsotg->dev, "Disabling channel\n"); in dwc2_hc_halt()
890 dev_vdbg(hsotg->dev, "DMA enabled\n"); in dwc2_hc_halt()
893 dwc2_writel(hsotg, hcchar, HCCHAR(chan->hc_num)); in dwc2_hc_halt()
894 chan->halt_status = halt_status; in dwc2_hc_halt()
898 dev_vdbg(hsotg->dev, "Channel enabled\n"); in dwc2_hc_halt()
899 chan->halt_pending = 1; in dwc2_hc_halt()
900 chan->halt_on_queue = 0; in dwc2_hc_halt()
903 dev_vdbg(hsotg->dev, "Channel disabled\n"); in dwc2_hc_halt()
904 chan->halt_on_queue = 1; in dwc2_hc_halt()
908 dev_vdbg(hsotg->dev, "%s: Channel %d\n", __func__, in dwc2_hc_halt()
909 chan->hc_num); in dwc2_hc_halt()
910 dev_vdbg(hsotg->dev, " hcchar: 0x%08x\n", in dwc2_hc_halt()
912 dev_vdbg(hsotg->dev, " halt_pending: %d\n", in dwc2_hc_halt()
913 chan->halt_pending); in dwc2_hc_halt()
914 dev_vdbg(hsotg->dev, " halt_on_queue: %d\n", in dwc2_hc_halt()
915 chan->halt_on_queue); in dwc2_hc_halt()
916 dev_vdbg(hsotg->dev, " halt_status: %d\n", in dwc2_hc_halt()
917 chan->halt_status); in dwc2_hc_halt()
922 * dwc2_hc_cleanup() - Clears the transfer state for a host channel
934 chan->xfer_started = 0; in dwc2_hc_cleanup()
936 list_del_init(&chan->split_order_list_entry); in dwc2_hc_cleanup()
942 dwc2_writel(hsotg, 0, HCINTMSK(chan->hc_num)); in dwc2_hc_cleanup()
945 dwc2_writel(hsotg, hcintmsk, HCINT(chan->hc_num)); in dwc2_hc_cleanup()
949 * dwc2_hc_set_even_odd_frame() - Sets the channel property that indicates in
956 * This function has no effect on non-periodic transfers
961 if (chan->ep_type == USB_ENDPOINT_XFER_INT || in dwc2_hc_set_even_odd_frame()
962 chan->ep_type == USB_ENDPOINT_XFER_ISOC) { in dwc2_hc_set_even_odd_frame()
995 host_speed = (chan->speed != USB_SPEED_HIGH && in dwc2_hc_set_even_odd_frame()
996 !chan->do_split) ? chan->speed : USB_SPEED_HIGH; in dwc2_hc_set_even_odd_frame()
1002 (hsotg->params.host_perio_tx_fifo_size - in dwc2_hc_set_even_odd_frame()
1010 * transfers. This should be an over-estimate and that should in dwc2_hc_set_even_odd_frame()
1014 chan->xfer_len + bytes_in_fifo); in dwc2_hc_set_even_odd_frame()
1021 wire_frame = dwc2_frame_num_inc(chan->qh->next_active_frame, 1); in dwc2_hc_set_even_odd_frame()
1033 chan->qh, wire_frame, frame_number, in dwc2_hc_set_even_odd_frame()
1046 chan->qh->next_active_frame = in dwc2_hc_set_even_odd_frame()
1060 if (chan->speed == USB_SPEED_HIGH) { in dwc2_set_pid_isoc()
1061 if (chan->ep_is_in) { in dwc2_set_pid_isoc()
1062 if (chan->multi_count == 1) in dwc2_set_pid_isoc()
1063 chan->data_pid_start = DWC2_HC_PID_DATA0; in dwc2_set_pid_isoc()
1064 else if (chan->multi_count == 2) in dwc2_set_pid_isoc()
1065 chan->data_pid_start = DWC2_HC_PID_DATA1; in dwc2_set_pid_isoc()
1067 chan->data_pid_start = DWC2_HC_PID_DATA2; in dwc2_set_pid_isoc()
1069 if (chan->multi_count == 1) in dwc2_set_pid_isoc()
1070 chan->data_pid_start = DWC2_HC_PID_DATA0; in dwc2_set_pid_isoc()
1072 chan->data_pid_start = DWC2_HC_PID_MDATA; in dwc2_set_pid_isoc()
1075 chan->data_pid_start = DWC2_HC_PID_DATA0; in dwc2_set_pid_isoc()
1080 * dwc2_hc_write_packet() - Writes a packet into the Tx FIFO associated with
1086 * This function should only be called in Slave mode. For a channel associated
1087 * with a non-periodic EP, the non-periodic Tx FIFO is written. For a channel
1100 u32 *data_buf = (u32 *)chan->xfer_buf; in dwc2_hc_write_packet()
1103 dev_vdbg(hsotg->dev, "%s()\n", __func__); in dwc2_hc_write_packet()
1105 remaining_count = chan->xfer_len - chan->xfer_count; in dwc2_hc_write_packet()
1106 if (remaining_count > chan->max_packet) in dwc2_hc_write_packet()
1107 byte_count = chan->max_packet; in dwc2_hc_write_packet()
1116 dwc2_writel(hsotg, *data_buf, HCFIFO(chan->hc_num)); in dwc2_hc_write_packet()
1122 dwc2_writel(hsotg, data, HCFIFO(chan->hc_num)); in dwc2_hc_write_packet()
1126 chan->xfer_count += byte_count; in dwc2_hc_write_packet()
1127 chan->xfer_buf += byte_count; in dwc2_hc_write_packet()
1131 * dwc2_hc_do_ping() - Starts a PING transfer
1136 * This function should only be called in Slave mode. The Do Ping bit is set in
1146 dev_vdbg(hsotg->dev, "%s: Channel %d\n", __func__, in dwc2_hc_do_ping()
1147 chan->hc_num); in dwc2_hc_do_ping()
1151 dwc2_writel(hsotg, hctsiz, HCTSIZ(chan->hc_num)); in dwc2_hc_do_ping()
1153 hcchar = dwc2_readl(hsotg, HCCHAR(chan->hc_num)); in dwc2_hc_do_ping()
1156 dwc2_writel(hsotg, hcchar, HCCHAR(chan->hc_num)); in dwc2_hc_do_ping()
1160 * dwc2_hc_start_transfer() - Does the setup for a data transfer for a host
1169 * This function may be called in either Slave mode or DMA mode. In Slave mode,
1173 * For an OUT transfer in Slave mode, it loads a data packet into the
1177 * For an IN transfer in Slave mode, a data packet is requested. The data
1181 * For a PING transfer in Slave mode, the Do Ping bit is set in the HCTSIZ
1186 * For a PING transfer in DMA mode, the HCTSIZ register is initialized with
1195 u32 max_hc_xfer_size = hsotg->params.max_transfer_size; in dwc2_hc_start_transfer()
1196 u16 max_hc_pkt_count = hsotg->params.max_packet_count; in dwc2_hc_start_transfer()
1203 dev_vdbg(hsotg->dev, "%s()\n", __func__); in dwc2_hc_start_transfer()
1205 if (chan->do_ping) { in dwc2_hc_start_transfer()
1206 if (!hsotg->params.host_dma) { in dwc2_hc_start_transfer()
1208 dev_vdbg(hsotg->dev, "ping, no DMA\n"); in dwc2_hc_start_transfer()
1210 chan->xfer_started = 1; in dwc2_hc_start_transfer()
1215 dev_vdbg(hsotg->dev, "ping, DMA\n"); in dwc2_hc_start_transfer()
1220 if (chan->do_split) { in dwc2_hc_start_transfer()
1222 dev_vdbg(hsotg->dev, "split\n"); in dwc2_hc_start_transfer()
1225 if (chan->complete_split && !chan->ep_is_in) in dwc2_hc_start_transfer()
1230 chan->xfer_len = 0; in dwc2_hc_start_transfer()
1231 else if (chan->ep_is_in || chan->xfer_len > chan->max_packet) in dwc2_hc_start_transfer()
1232 chan->xfer_len = chan->max_packet; in dwc2_hc_start_transfer()
1233 else if (!chan->ep_is_in && chan->xfer_len > 188) in dwc2_hc_start_transfer()
1234 chan->xfer_len = 188; in dwc2_hc_start_transfer()
1236 hctsiz |= chan->xfer_len << TSIZ_XFERSIZE_SHIFT & in dwc2_hc_start_transfer()
1240 if (chan->ep_type == USB_ENDPOINT_XFER_INT || in dwc2_hc_start_transfer()
1241 chan->ep_type == USB_ENDPOINT_XFER_ISOC) in dwc2_hc_start_transfer()
1247 dev_vdbg(hsotg->dev, "no split\n"); in dwc2_hc_start_transfer()
1252 if (chan->ep_type == USB_ENDPOINT_XFER_INT || in dwc2_hc_start_transfer()
1253 chan->ep_type == USB_ENDPOINT_XFER_ISOC) { in dwc2_hc_start_transfer()
1262 chan->multi_count * chan->max_packet; in dwc2_hc_start_transfer()
1264 if (chan->xfer_len > max_periodic_len) in dwc2_hc_start_transfer()
1265 chan->xfer_len = max_periodic_len; in dwc2_hc_start_transfer()
1266 } else if (chan->xfer_len > max_hc_xfer_size) { in dwc2_hc_start_transfer()
1271 chan->xfer_len = in dwc2_hc_start_transfer()
1272 max_hc_xfer_size - chan->max_packet + 1; in dwc2_hc_start_transfer()
1275 if (chan->xfer_len > 0) { in dwc2_hc_start_transfer()
1276 num_packets = (chan->xfer_len + chan->max_packet - 1) / in dwc2_hc_start_transfer()
1277 chan->max_packet; in dwc2_hc_start_transfer()
1280 chan->xfer_len = num_packets * chan->max_packet; in dwc2_hc_start_transfer()
1281 } else if (chan->ep_is_in) { in dwc2_hc_start_transfer()
1288 chan->xfer_len = num_packets * chan->max_packet; in dwc2_hc_start_transfer()
1295 if (chan->ep_type == USB_ENDPOINT_XFER_INT || in dwc2_hc_start_transfer()
1296 chan->ep_type == USB_ENDPOINT_XFER_ISOC) in dwc2_hc_start_transfer()
1301 chan->multi_count = num_packets; in dwc2_hc_start_transfer()
1303 if (chan->ep_type == USB_ENDPOINT_XFER_ISOC) in dwc2_hc_start_transfer()
1306 hctsiz |= chan->xfer_len << TSIZ_XFERSIZE_SHIFT & in dwc2_hc_start_transfer()
1309 /* The ec_mc gets the multi_count for non-split */ in dwc2_hc_start_transfer()
1310 ec_mc = chan->multi_count; in dwc2_hc_start_transfer()
1313 chan->start_pkt_count = num_packets; in dwc2_hc_start_transfer()
1315 hctsiz |= chan->data_pid_start << TSIZ_SC_MC_PID_SHIFT & in dwc2_hc_start_transfer()
1317 dwc2_writel(hsotg, hctsiz, HCTSIZ(chan->hc_num)); in dwc2_hc_start_transfer()
1319 dev_vdbg(hsotg->dev, "Wrote %08x to HCTSIZ(%d)\n", in dwc2_hc_start_transfer()
1320 hctsiz, chan->hc_num); in dwc2_hc_start_transfer()
1322 dev_vdbg(hsotg->dev, "%s: Channel %d\n", __func__, in dwc2_hc_start_transfer()
1323 chan->hc_num); in dwc2_hc_start_transfer()
1324 dev_vdbg(hsotg->dev, " Xfer Size: %d\n", in dwc2_hc_start_transfer()
1327 dev_vdbg(hsotg->dev, " Num Pkts: %d\n", in dwc2_hc_start_transfer()
1330 dev_vdbg(hsotg->dev, " Start PID: %d\n", in dwc2_hc_start_transfer()
1335 if (hsotg->params.host_dma) { in dwc2_hc_start_transfer()
1338 if (chan->align_buf) { in dwc2_hc_start_transfer()
1340 dev_vdbg(hsotg->dev, "align_buf\n"); in dwc2_hc_start_transfer()
1341 dma_addr = chan->align_buf; in dwc2_hc_start_transfer()
1343 dma_addr = chan->xfer_dma; in dwc2_hc_start_transfer()
1345 dwc2_writel(hsotg, (u32)dma_addr, HCDMA(chan->hc_num)); in dwc2_hc_start_transfer()
1348 dev_vdbg(hsotg->dev, "Wrote %08lx to HCDMA(%d)\n", in dwc2_hc_start_transfer()
1349 (unsigned long)dma_addr, chan->hc_num); in dwc2_hc_start_transfer()
1353 if (chan->do_split) { in dwc2_hc_start_transfer()
1354 u32 hcsplt = dwc2_readl(hsotg, HCSPLT(chan->hc_num)); in dwc2_hc_start_transfer()
1357 dwc2_writel(hsotg, hcsplt, HCSPLT(chan->hc_num)); in dwc2_hc_start_transfer()
1360 hcchar = dwc2_readl(hsotg, HCCHAR(chan->hc_num)); in dwc2_hc_start_transfer()
1366 dev_warn(hsotg->dev, in dwc2_hc_start_transfer()
1368 __func__, chan->hc_num, hcchar); in dwc2_hc_start_transfer()
1375 dev_vdbg(hsotg->dev, " Multi Cnt: %d\n", in dwc2_hc_start_transfer()
1379 dwc2_writel(hsotg, hcchar, HCCHAR(chan->hc_num)); in dwc2_hc_start_transfer()
1381 dev_vdbg(hsotg->dev, "Wrote %08x to HCCHAR(%d)\n", hcchar, in dwc2_hc_start_transfer()
1382 chan->hc_num); in dwc2_hc_start_transfer()
1384 chan->xfer_started = 1; in dwc2_hc_start_transfer()
1385 chan->requests++; in dwc2_hc_start_transfer()
1387 if (!hsotg->params.host_dma && in dwc2_hc_start_transfer()
1388 !chan->ep_is_in && chan->xfer_len > 0) in dwc2_hc_start_transfer()
1394 * dwc2_hc_start_transfer_ddma() - Does the setup for a data transfer for a
1395 * host channel and starts the transfer in Descriptor DMA mode
1402 * with micro-frame bitmap.
1413 if (chan->do_ping) in dwc2_hc_start_transfer_ddma()
1416 if (chan->ep_type == USB_ENDPOINT_XFER_ISOC) in dwc2_hc_start_transfer_ddma()
1419 /* Packet Count and Xfer Size are not used in Descriptor DMA mode */ in dwc2_hc_start_transfer_ddma()
1420 hctsiz |= chan->data_pid_start << TSIZ_SC_MC_PID_SHIFT & in dwc2_hc_start_transfer_ddma()
1423 /* 0 - 1 descriptor, 1 - 2 descriptors, etc */ in dwc2_hc_start_transfer_ddma()
1424 hctsiz |= (chan->ntd - 1) << TSIZ_NTD_SHIFT & TSIZ_NTD_MASK; in dwc2_hc_start_transfer_ddma()
1426 /* Non-zero only for high-speed interrupt endpoints */ in dwc2_hc_start_transfer_ddma()
1427 hctsiz |= chan->schinfo << TSIZ_SCHINFO_SHIFT & TSIZ_SCHINFO_MASK; in dwc2_hc_start_transfer_ddma()
1430 dev_vdbg(hsotg->dev, "%s: Channel %d\n", __func__, in dwc2_hc_start_transfer_ddma()
1431 chan->hc_num); in dwc2_hc_start_transfer_ddma()
1432 dev_vdbg(hsotg->dev, " Start PID: %d\n", in dwc2_hc_start_transfer_ddma()
1433 chan->data_pid_start); in dwc2_hc_start_transfer_ddma()
1434 dev_vdbg(hsotg->dev, " NTD: %d\n", chan->ntd - 1); in dwc2_hc_start_transfer_ddma()
1437 dwc2_writel(hsotg, hctsiz, HCTSIZ(chan->hc_num)); in dwc2_hc_start_transfer_ddma()
1439 dma_sync_single_for_device(hsotg->dev, chan->desc_list_addr, in dwc2_hc_start_transfer_ddma()
1440 chan->desc_list_sz, DMA_TO_DEVICE); in dwc2_hc_start_transfer_ddma()
1442 dwc2_writel(hsotg, chan->desc_list_addr, HCDMA(chan->hc_num)); in dwc2_hc_start_transfer_ddma()
1445 dev_vdbg(hsotg->dev, "Wrote %pad to HCDMA(%d)\n", in dwc2_hc_start_transfer_ddma()
1446 &chan->desc_list_addr, chan->hc_num); in dwc2_hc_start_transfer_ddma()
1448 hcchar = dwc2_readl(hsotg, HCCHAR(chan->hc_num)); in dwc2_hc_start_transfer_ddma()
1450 hcchar |= chan->multi_count << HCCHAR_MULTICNT_SHIFT & in dwc2_hc_start_transfer_ddma()
1454 dev_warn(hsotg->dev, in dwc2_hc_start_transfer_ddma()
1456 __func__, chan->hc_num, hcchar); in dwc2_hc_start_transfer_ddma()
1463 dev_vdbg(hsotg->dev, " Multi Cnt: %d\n", in dwc2_hc_start_transfer_ddma()
1467 dwc2_writel(hsotg, hcchar, HCCHAR(chan->hc_num)); in dwc2_hc_start_transfer_ddma()
1469 dev_vdbg(hsotg->dev, "Wrote %08x to HCCHAR(%d)\n", hcchar, in dwc2_hc_start_transfer_ddma()
1470 chan->hc_num); in dwc2_hc_start_transfer_ddma()
1472 chan->xfer_started = 1; in dwc2_hc_start_transfer_ddma()
1473 chan->requests++; in dwc2_hc_start_transfer_ddma()
1477 * dwc2_hc_continue_transfer() - Continues a data transfer that was started by
1484 * Data FIFO. This function should only be called in Slave mode. In DMA mode,
1500 dev_vdbg(hsotg->dev, "%s: Channel %d\n", __func__, in dwc2_hc_continue_transfer()
1501 chan->hc_num); in dwc2_hc_continue_transfer()
1503 if (chan->do_split) in dwc2_hc_continue_transfer()
1507 if (chan->data_pid_start == DWC2_HC_PID_SETUP) in dwc2_hc_continue_transfer()
1511 if (chan->ep_is_in) { in dwc2_hc_continue_transfer()
1514 * back-to-back INs are issued and NAKs are received for both, in dwc2_hc_continue_transfer()
1524 u32 hcchar = dwc2_readl(hsotg, HCCHAR(chan->hc_num)); in dwc2_hc_continue_transfer()
1530 dev_vdbg(hsotg->dev, " IN xfer: hcchar = 0x%08x\n", in dwc2_hc_continue_transfer()
1532 dwc2_writel(hsotg, hcchar, HCCHAR(chan->hc_num)); in dwc2_hc_continue_transfer()
1533 chan->requests++; in dwc2_hc_continue_transfer()
1539 if (chan->xfer_count < chan->xfer_len) { in dwc2_hc_continue_transfer()
1540 if (chan->ep_type == USB_ENDPOINT_XFER_INT || in dwc2_hc_continue_transfer()
1541 chan->ep_type == USB_ENDPOINT_XFER_ISOC) { in dwc2_hc_continue_transfer()
1543 HCCHAR(chan->hc_num)); in dwc2_hc_continue_transfer()
1551 chan->requests++; in dwc2_hc_continue_transfer()
1566 * -ETIMEDOUT and frees the QTD.
1577 list_for_each_entry_safe(qtd, qtd_tmp, &qh->qtd_list, in dwc2_kill_urbs_in_qh_list()
1579 dwc2_host_complete(hsotg, qtd, -ECONNRESET); in dwc2_kill_urbs_in_qh_list()
1592 if (!qh_list->next) in dwc2_qh_list_free()
1596 spin_lock_irqsave(&hsotg->lock, flags); in dwc2_qh_list_free()
1605 list_for_each_entry_safe(qtd, qtd_tmp, &qh->qtd_list, in dwc2_qh_list_free()
1609 if (qh->channel && qh->channel->qh == qh) in dwc2_qh_list_free()
1610 qh->channel->qh = NULL; in dwc2_qh_list_free()
1612 spin_unlock_irqrestore(&hsotg->lock, flags); in dwc2_qh_list_free()
1614 spin_lock_irqsave(&hsotg->lock, flags); in dwc2_qh_list_free()
1617 spin_unlock_irqrestore(&hsotg->lock, flags); in dwc2_qh_list_free()
1621 * Responds with an error status of -ETIMEDOUT to all URBs in the non-periodic
1630 dwc2_kill_urbs_in_qh_list(hsotg, &hsotg->non_periodic_sched_inactive); in dwc2_kill_all_urbs()
1631 dwc2_kill_urbs_in_qh_list(hsotg, &hsotg->non_periodic_sched_waiting); in dwc2_kill_all_urbs()
1632 dwc2_kill_urbs_in_qh_list(hsotg, &hsotg->non_periodic_sched_active); in dwc2_kill_all_urbs()
1633 dwc2_kill_urbs_in_qh_list(hsotg, &hsotg->periodic_sched_inactive); in dwc2_kill_all_urbs()
1634 dwc2_kill_urbs_in_qh_list(hsotg, &hsotg->periodic_sched_ready); in dwc2_kill_all_urbs()
1635 dwc2_kill_urbs_in_qh_list(hsotg, &hsotg->periodic_sched_assigned); in dwc2_kill_all_urbs()
1636 dwc2_kill_urbs_in_qh_list(hsotg, &hsotg->periodic_sched_queued); in dwc2_kill_all_urbs()
1640 * dwc2_hcd_start() - Starts the HCD when switching to Host mode
1648 if (hsotg->op_state == OTG_STATE_B_HOST) { in dwc2_hcd_start()
1650 * Reset the port. During a HNP mode switch the reset in dwc2_hcd_start()
1659 queue_delayed_work(hsotg->wq_otg, &hsotg->start_work, in dwc2_hcd_start()
1666 int num_channels = hsotg->params.host_channels; in dwc2_hcd_cleanup_channels()
1671 if (!hsotg->params.host_dma) { in dwc2_hcd_cleanup_channels()
1672 /* Flush out any channel requests in slave mode */ in dwc2_hcd_cleanup_channels()
1674 channel = hsotg->hc_ptr_array[i]; in dwc2_hcd_cleanup_channels()
1675 if (!list_empty(&channel->hc_list_entry)) in dwc2_hcd_cleanup_channels()
1687 channel = hsotg->hc_ptr_array[i]; in dwc2_hcd_cleanup_channels()
1688 if (!list_empty(&channel->hc_list_entry)) in dwc2_hcd_cleanup_channels()
1698 list_add_tail(&channel->hc_list_entry, &hsotg->free_hc_list); in dwc2_hcd_cleanup_channels()
1704 channel->qh = NULL; in dwc2_hcd_cleanup_channels()
1707 if (hsotg->params.uframe_sched) { in dwc2_hcd_cleanup_channels()
1708 hsotg->available_host_channels = in dwc2_hcd_cleanup_channels()
1709 hsotg->params.host_channels; in dwc2_hcd_cleanup_channels()
1711 hsotg->non_periodic_channels = 0; in dwc2_hcd_cleanup_channels()
1712 hsotg->periodic_channels = 0; in dwc2_hcd_cleanup_channels()
1717 * dwc2_hcd_connect() - Handles connect of the HCD
1725 if (hsotg->lx_state != DWC2_L0) in dwc2_hcd_connect()
1726 usb_hcd_resume_root_hub(hsotg->priv); in dwc2_hcd_connect()
1728 hsotg->flags.b.port_connect_status_change = 1; in dwc2_hcd_connect()
1729 hsotg->flags.b.port_connect_status = 1; in dwc2_hcd_connect()
1733 * dwc2_hcd_disconnect() - Handles disconnect of the HCD
1746 hsotg->flags.b.port_connect_status_change = 1; in dwc2_hcd_disconnect()
1747 hsotg->flags.b.port_connect_status = 0; in dwc2_hcd_disconnect()
1762 * mode. If still in host mode, need to keep power on to detect a in dwc2_hcd_disconnect()
1766 if (hsotg->op_state != OTG_STATE_A_SUSPEND) { in dwc2_hcd_disconnect()
1767 dev_dbg(hsotg->dev, "Disconnect: PortPower off\n"); in dwc2_hcd_disconnect()
1789 * 4. dwc2_port_intr() - clears connect interrupt in dwc2_hcd_disconnect()
1790 * 5. dwc2_handle_common_intr() - calls here in dwc2_hcd_disconnect()
1803 * dwc2_hcd_rem_wakeup() - Handles Remote Wakeup
1809 if (hsotg->bus_suspended) { in dwc2_hcd_rem_wakeup()
1810 hsotg->flags.b.port_suspend_change = 1; in dwc2_hcd_rem_wakeup()
1811 usb_hcd_resume_root_hub(hsotg->priv); in dwc2_hcd_rem_wakeup()
1814 if (hsotg->lx_state == DWC2_L1) in dwc2_hcd_rem_wakeup()
1815 hsotg->flags.b.port_l1_change = 1; in dwc2_hcd_rem_wakeup()
1819 * dwc2_hcd_stop() - Halts the DWC_otg host mode operations in a clean manner
1827 dev_dbg(hsotg->dev, "DWC OTG HCD STOP\n"); in dwc2_hcd_stop()
1835 /* Turn off all host-specific interrupts */ in dwc2_hcd_stop()
1839 dev_dbg(hsotg->dev, "PortPower off\n"); in dwc2_hcd_stop()
1852 if (!hsotg->flags.b.port_connect_status) { in dwc2_hcd_urb_enqueue()
1854 dev_err(hsotg->dev, "Not connected\n"); in dwc2_hcd_urb_enqueue()
1855 return -ENODEV; in dwc2_hcd_urb_enqueue()
1858 dev_speed = dwc2_host_get_speed(hsotg, urb->priv); in dwc2_hcd_urb_enqueue()
1862 (hsotg->hw_params.fs_phy_type == GHWCFG2_FS_PHY_TYPE_DEDICATED) && in dwc2_hcd_urb_enqueue()
1863 (hsotg->hw_params.hs_phy_type == GHWCFG2_HS_PHY_TYPE_UTMI)) { in dwc2_hcd_urb_enqueue()
1868 return -ENODEV; in dwc2_hcd_urb_enqueue()
1872 return -EINVAL; in dwc2_hcd_urb_enqueue()
1877 dev_err(hsotg->dev, in dwc2_hcd_urb_enqueue()
1887 if (qtd->qh->ep_type == USB_ENDPOINT_XFER_BULK && in dwc2_hcd_urb_enqueue()
1888 !(qtd->urb->flags & URB_GIVEBACK_ASAP)) in dwc2_hcd_urb_enqueue()
1910 urb_qtd = urb->qtd; in dwc2_hcd_urb_dequeue()
1912 dev_dbg(hsotg->dev, "## Urb QTD is NULL ##\n"); in dwc2_hcd_urb_dequeue()
1913 return -EINVAL; in dwc2_hcd_urb_dequeue()
1916 qh = urb_qtd->qh; in dwc2_hcd_urb_dequeue()
1918 dev_dbg(hsotg->dev, "## Urb QTD QH is NULL ##\n"); in dwc2_hcd_urb_dequeue()
1919 return -EINVAL; in dwc2_hcd_urb_dequeue()
1922 urb->priv = NULL; in dwc2_hcd_urb_dequeue()
1924 if (urb_qtd->in_process && qh->channel) { in dwc2_hcd_urb_dequeue()
1925 dwc2_dump_channel_info(hsotg, qh->channel); in dwc2_hcd_urb_dequeue()
1928 if (hsotg->flags.b.port_connect_status) in dwc2_hcd_urb_dequeue()
1930 * If still connected (i.e. in host mode), halt the in dwc2_hcd_urb_dequeue()
1934 * device mode. in dwc2_hcd_urb_dequeue()
1936 dwc2_hc_halt(hsotg, qh->channel, in dwc2_hcd_urb_dequeue()
1944 if (!hsotg->params.dma_desc_enable) { in dwc2_hcd_urb_dequeue()
1945 u8 in_process = urb_qtd->in_process; in dwc2_hcd_urb_dequeue()
1950 qh->channel = NULL; in dwc2_hcd_urb_dequeue()
1951 } else if (list_empty(&qh->qtd_list)) { in dwc2_hcd_urb_dequeue()
1970 spin_lock_irqsave(&hsotg->lock, flags); in dwc2_hcd_endpoint_disable()
1972 qh = ep->hcpriv; in dwc2_hcd_endpoint_disable()
1974 rc = -EINVAL; in dwc2_hcd_endpoint_disable()
1978 while (!list_empty(&qh->qtd_list) && retry--) { in dwc2_hcd_endpoint_disable()
1980 dev_err(hsotg->dev, in dwc2_hcd_endpoint_disable()
1982 rc = -EBUSY; in dwc2_hcd_endpoint_disable()
1986 spin_unlock_irqrestore(&hsotg->lock, flags); in dwc2_hcd_endpoint_disable()
1988 spin_lock_irqsave(&hsotg->lock, flags); in dwc2_hcd_endpoint_disable()
1989 qh = ep->hcpriv; in dwc2_hcd_endpoint_disable()
1991 rc = -EINVAL; in dwc2_hcd_endpoint_disable()
1999 list_for_each_entry_safe(qtd, qtd_tmp, &qh->qtd_list, qtd_list_entry) in dwc2_hcd_endpoint_disable()
2002 ep->hcpriv = NULL; in dwc2_hcd_endpoint_disable()
2004 if (qh->channel && qh->channel->qh == qh) in dwc2_hcd_endpoint_disable()
2005 qh->channel->qh = NULL; in dwc2_hcd_endpoint_disable()
2007 spin_unlock_irqrestore(&hsotg->lock, flags); in dwc2_hcd_endpoint_disable()
2014 ep->hcpriv = NULL; in dwc2_hcd_endpoint_disable()
2015 spin_unlock_irqrestore(&hsotg->lock, flags); in dwc2_hcd_endpoint_disable()
2024 struct dwc2_qh *qh = ep->hcpriv; in dwc2_hcd_endpoint_reset()
2027 return -EINVAL; in dwc2_hcd_endpoint_reset()
2029 qh->data_toggle = DWC2_HC_PID_DATA0; in dwc2_hcd_endpoint_reset()
2035 * dwc2_core_init() - Initializes the DWC_otg controller registers and
2036 * prepares the core for device mode or host mode operation
2046 dev_dbg(hsotg->dev, "%s(%p)\n", __func__, hsotg); in dwc2_core_init()
2052 if (hsotg->params.phy_ulpi_ext_vbus) in dwc2_core_init()
2057 if (hsotg->params.ts_dline) in dwc2_core_init()
2065 * We only need to reset the controller if this is a re-init. in dwc2_core_init()
2072 dev_err(hsotg->dev, "%s(): Reset failed, aborting\n", in dwc2_core_init()
2079 * This needs to happen in FS mode before any other programming occurs in dwc2_core_init()
2098 /* Clear the SRP success bit for FS-I2c */ in dwc2_core_init()
2099 hsotg->srp_success = 0; in dwc2_core_init()
2105 * Do device or host initialization based on mode during PCD and in dwc2_core_init()
2109 dev_dbg(hsotg->dev, "Host Mode\n"); in dwc2_core_init()
2110 hsotg->op_state = OTG_STATE_A_HOST; in dwc2_core_init()
2112 dev_dbg(hsotg->dev, "Device Mode\n"); in dwc2_core_init()
2113 hsotg->op_state = OTG_STATE_B_PERIPHERAL; in dwc2_core_init()
2120 * dwc2_core_host_init() - Initializes the DWC_otg controller registers for
2121 * Host mode
2133 dev_dbg(hsotg->dev, "%s(%p)\n", __func__, hsotg); in dwc2_core_host_init()
2152 if (hsotg->params.speed == DWC2_SPEED_PARAM_FULL || in dwc2_core_host_init()
2153 hsotg->params.speed == DWC2_SPEED_PARAM_LOW) { in dwc2_core_host_init()
2164 if (hsotg->params.reload_ctl) { in dwc2_core_host_init()
2170 if (hsotg->params.dma_desc_enable) { in dwc2_core_host_init()
2171 u32 op_mode = hsotg->hw_params.op_mode; in dwc2_core_host_init()
2173 if (hsotg->hw_params.snpsid < DWC2_CORE_REV_2_90a || in dwc2_core_host_init()
2174 !hsotg->hw_params.dma_desc_enable || in dwc2_core_host_init()
2178 dev_err(hsotg->dev, in dwc2_core_host_init()
2179 "Hardware does not support descriptor DMA mode -\n"); in dwc2_core_host_init()
2180 dev_err(hsotg->dev, in dwc2_core_host_init()
2181 "falling back to buffer DMA mode.\n"); in dwc2_core_host_init()
2182 hsotg->params.dma_desc_enable = false; in dwc2_core_host_init()
2193 /* TODO - check this */ in dwc2_core_host_init()
2208 if (!hsotg->params.dma_desc_enable) { in dwc2_core_host_init()
2213 num_channels = hsotg->params.host_channels; in dwc2_core_host_init()
2231 dev_dbg(hsotg->dev, "%s: Halt channel %d\n", in dwc2_core_host_init()
2237 dev_warn(hsotg->dev, in dwc2_core_host_init()
2245 /* Enable ACG feature in host mode, if supported */ in dwc2_core_host_init()
2249 dev_dbg(hsotg->dev, "Init: Port Power? op_state=%d\n", hsotg->op_state); in dwc2_core_host_init()
2250 if (hsotg->op_state == OTG_STATE_A_HOST) { in dwc2_core_host_init()
2253 dev_dbg(hsotg->dev, "Init: Power Port (%d)\n", in dwc2_core_host_init()
2275 hsotg->flags.d32 = 0; in dwc2_hcd_reinit()
2276 hsotg->non_periodic_qh_ptr = &hsotg->non_periodic_sched_active; in dwc2_hcd_reinit()
2278 if (hsotg->params.uframe_sched) { in dwc2_hcd_reinit()
2279 hsotg->available_host_channels = in dwc2_hcd_reinit()
2280 hsotg->params.host_channels; in dwc2_hcd_reinit()
2282 hsotg->non_periodic_channels = 0; in dwc2_hcd_reinit()
2283 hsotg->periodic_channels = 0; in dwc2_hcd_reinit()
2290 list_for_each_entry_safe(chan, chan_tmp, &hsotg->free_hc_list, in dwc2_hcd_reinit()
2292 list_del_init(&chan->hc_list_entry); in dwc2_hcd_reinit()
2294 num_channels = hsotg->params.host_channels; in dwc2_hcd_reinit()
2296 chan = hsotg->hc_ptr_array[i]; in dwc2_hcd_reinit()
2297 list_add_tail(&chan->hc_list_entry, &hsotg->free_hc_list); in dwc2_hcd_reinit()
2301 /* Initialize the DWC core for host mode operation */ in dwc2_hcd_reinit()
2311 chan->do_split = 1; in dwc2_hc_init_split()
2312 chan->xact_pos = qtd->isoc_split_pos; in dwc2_hc_init_split()
2313 chan->complete_split = qtd->complete_split; in dwc2_hc_init_split()
2314 dwc2_host_hub_info(hsotg, urb->priv, &hub_addr, &hub_port); in dwc2_hc_init_split()
2315 chan->hub_addr = (u8)hub_addr; in dwc2_hc_init_split()
2316 chan->hub_port = (u8)hub_port; in dwc2_hc_init_split()
2323 struct dwc2_hcd_urb *urb = qtd->urb; in dwc2_hc_init_xfer()
2326 switch (dwc2_hcd_get_pipe_type(&urb->pipe_info)) { in dwc2_hc_init_xfer()
2328 chan->ep_type = USB_ENDPOINT_XFER_CONTROL; in dwc2_hc_init_xfer()
2330 switch (qtd->control_phase) { in dwc2_hc_init_xfer()
2332 dev_vdbg(hsotg->dev, " Control setup transaction\n"); in dwc2_hc_init_xfer()
2333 chan->do_ping = 0; in dwc2_hc_init_xfer()
2334 chan->ep_is_in = 0; in dwc2_hc_init_xfer()
2335 chan->data_pid_start = DWC2_HC_PID_SETUP; in dwc2_hc_init_xfer()
2336 if (hsotg->params.host_dma) in dwc2_hc_init_xfer()
2337 chan->xfer_dma = urb->setup_dma; in dwc2_hc_init_xfer()
2339 chan->xfer_buf = urb->setup_packet; in dwc2_hc_init_xfer()
2340 chan->xfer_len = 8; in dwc2_hc_init_xfer()
2344 dev_vdbg(hsotg->dev, " Control data transaction\n"); in dwc2_hc_init_xfer()
2345 chan->data_pid_start = qtd->data_toggle; in dwc2_hc_init_xfer()
2353 dev_vdbg(hsotg->dev, " Control status transaction\n"); in dwc2_hc_init_xfer()
2354 if (urb->length == 0) in dwc2_hc_init_xfer()
2355 chan->ep_is_in = 1; in dwc2_hc_init_xfer()
2357 chan->ep_is_in = in dwc2_hc_init_xfer()
2358 dwc2_hcd_is_pipe_out(&urb->pipe_info); in dwc2_hc_init_xfer()
2359 if (chan->ep_is_in) in dwc2_hc_init_xfer()
2360 chan->do_ping = 0; in dwc2_hc_init_xfer()
2361 chan->data_pid_start = DWC2_HC_PID_DATA1; in dwc2_hc_init_xfer()
2362 chan->xfer_len = 0; in dwc2_hc_init_xfer()
2363 if (hsotg->params.host_dma) in dwc2_hc_init_xfer()
2364 chan->xfer_dma = hsotg->status_buf_dma; in dwc2_hc_init_xfer()
2366 chan->xfer_buf = hsotg->status_buf; in dwc2_hc_init_xfer()
2372 chan->ep_type = USB_ENDPOINT_XFER_BULK; in dwc2_hc_init_xfer()
2376 chan->ep_type = USB_ENDPOINT_XFER_INT; in dwc2_hc_init_xfer()
2380 chan->ep_type = USB_ENDPOINT_XFER_ISOC; in dwc2_hc_init_xfer()
2381 if (hsotg->params.dma_desc_enable) in dwc2_hc_init_xfer()
2384 frame_desc = &urb->iso_descs[qtd->isoc_frame_index]; in dwc2_hc_init_xfer()
2385 frame_desc->status = 0; in dwc2_hc_init_xfer()
2387 if (hsotg->params.host_dma) { in dwc2_hc_init_xfer()
2388 chan->xfer_dma = urb->dma; in dwc2_hc_init_xfer()
2389 chan->xfer_dma += frame_desc->offset + in dwc2_hc_init_xfer()
2390 qtd->isoc_split_offset; in dwc2_hc_init_xfer()
2392 chan->xfer_buf = urb->buf; in dwc2_hc_init_xfer()
2393 chan->xfer_buf += frame_desc->offset + in dwc2_hc_init_xfer()
2394 qtd->isoc_split_offset; in dwc2_hc_init_xfer()
2397 chan->xfer_len = frame_desc->length - qtd->isoc_split_offset; in dwc2_hc_init_xfer()
2399 if (chan->xact_pos == DWC2_HCSPLT_XACTPOS_ALL) { in dwc2_hc_init_xfer()
2400 if (chan->xfer_len <= 188) in dwc2_hc_init_xfer()
2401 chan->xact_pos = DWC2_HCSPLT_XACTPOS_ALL; in dwc2_hc_init_xfer()
2403 chan->xact_pos = DWC2_HCSPLT_XACTPOS_BEGIN; in dwc2_hc_init_xfer()
2413 if (!hsotg->unaligned_cache || in dwc2_alloc_split_dma_aligned_buf()
2414 chan->max_packet > DWC2_KMEM_UNALIGNED_BUF_SIZE) in dwc2_alloc_split_dma_aligned_buf()
2415 return -ENOMEM; in dwc2_alloc_split_dma_aligned_buf()
2417 if (!qh->dw_align_buf) { in dwc2_alloc_split_dma_aligned_buf()
2418 qh->dw_align_buf = kmem_cache_alloc(hsotg->unaligned_cache, in dwc2_alloc_split_dma_aligned_buf()
2420 if (!qh->dw_align_buf) in dwc2_alloc_split_dma_aligned_buf()
2421 return -ENOMEM; in dwc2_alloc_split_dma_aligned_buf()
2424 qh->dw_align_buf_dma = dma_map_single(hsotg->dev, qh->dw_align_buf, in dwc2_alloc_split_dma_aligned_buf()
2428 if (dma_mapping_error(hsotg->dev, qh->dw_align_buf_dma)) { in dwc2_alloc_split_dma_aligned_buf()
2429 dev_err(hsotg->dev, "can't map align_buf\n"); in dwc2_alloc_split_dma_aligned_buf()
2430 chan->align_buf = 0; in dwc2_alloc_split_dma_aligned_buf()
2431 return -EINVAL; in dwc2_alloc_split_dma_aligned_buf()
2434 chan->align_buf = qh->dw_align_buf_dma; in dwc2_alloc_split_dma_aligned_buf()
2445 if (!(urb->transfer_flags & URB_ALIGNED_TEMP_BUFFER)) in dwc2_free_dma_aligned_buffer()
2448 /* Restore urb->transfer_buffer from the end of the allocated area */ in dwc2_free_dma_aligned_buffer()
2450 PTR_ALIGN(urb->transfer_buffer + urb->transfer_buffer_length, in dwc2_free_dma_aligned_buffer()
2452 sizeof(urb->transfer_buffer)); in dwc2_free_dma_aligned_buffer()
2455 if (usb_pipeisoc(urb->pipe)) in dwc2_free_dma_aligned_buffer()
2456 length = urb->transfer_buffer_length; in dwc2_free_dma_aligned_buffer()
2458 length = urb->actual_length; in dwc2_free_dma_aligned_buffer()
2460 memcpy(stored_xfer_buffer, urb->transfer_buffer, length); in dwc2_free_dma_aligned_buffer()
2462 kfree(urb->transfer_buffer); in dwc2_free_dma_aligned_buffer()
2463 urb->transfer_buffer = stored_xfer_buffer; in dwc2_free_dma_aligned_buffer()
2465 urb->transfer_flags &= ~URB_ALIGNED_TEMP_BUFFER; in dwc2_free_dma_aligned_buffer()
2473 if (urb->num_sgs || urb->sg || in dwc2_alloc_dma_aligned_buffer()
2474 urb->transfer_buffer_length == 0 || in dwc2_alloc_dma_aligned_buffer()
2475 !((uintptr_t)urb->transfer_buffer & (DWC2_USB_DMA_ALIGN - 1))) in dwc2_alloc_dma_aligned_buffer()
2483 kmalloc_size = urb->transfer_buffer_length + in dwc2_alloc_dma_aligned_buffer()
2484 (dma_get_cache_alignment() - 1) + in dwc2_alloc_dma_aligned_buffer()
2485 sizeof(urb->transfer_buffer); in dwc2_alloc_dma_aligned_buffer()
2489 return -ENOMEM; in dwc2_alloc_dma_aligned_buffer()
2492 * Position value of original urb->transfer_buffer pointer to the end in dwc2_alloc_dma_aligned_buffer()
2495 memcpy(PTR_ALIGN(kmalloc_ptr + urb->transfer_buffer_length, in dwc2_alloc_dma_aligned_buffer()
2497 &urb->transfer_buffer, sizeof(urb->transfer_buffer)); in dwc2_alloc_dma_aligned_buffer()
2500 memcpy(kmalloc_ptr, urb->transfer_buffer, in dwc2_alloc_dma_aligned_buffer()
2501 urb->transfer_buffer_length); in dwc2_alloc_dma_aligned_buffer()
2502 urb->transfer_buffer = kmalloc_ptr; in dwc2_alloc_dma_aligned_buffer()
2504 urb->transfer_flags |= URB_ALIGNED_TEMP_BUFFER; in dwc2_alloc_dma_aligned_buffer()
2515 WARN_ON_ONCE(urb->setup_dma && in dwc2_map_urb_for_dma()
2516 (urb->setup_dma & (DWC2_USB_DMA_ALIGN - 1))); in dwc2_map_urb_for_dma()
2536 * dwc2_assign_and_init_hc() - Assigns transactions from a QTD to a free host
2551 dev_vdbg(hsotg->dev, "%s(%p,%p)\n", __func__, hsotg, qh); in dwc2_assign_and_init_hc()
2553 if (list_empty(&qh->qtd_list)) { in dwc2_assign_and_init_hc()
2554 dev_dbg(hsotg->dev, "No QTDs in QH list\n"); in dwc2_assign_and_init_hc()
2555 return -ENOMEM; in dwc2_assign_and_init_hc()
2558 if (list_empty(&hsotg->free_hc_list)) { in dwc2_assign_and_init_hc()
2559 dev_dbg(hsotg->dev, "No free channel to assign\n"); in dwc2_assign_and_init_hc()
2560 return -ENOMEM; in dwc2_assign_and_init_hc()
2563 chan = list_first_entry(&hsotg->free_hc_list, struct dwc2_host_chan, in dwc2_assign_and_init_hc()
2567 list_del_init(&chan->hc_list_entry); in dwc2_assign_and_init_hc()
2569 qtd = list_first_entry(&qh->qtd_list, struct dwc2_qtd, qtd_list_entry); in dwc2_assign_and_init_hc()
2570 urb = qtd->urb; in dwc2_assign_and_init_hc()
2571 qh->channel = chan; in dwc2_assign_and_init_hc()
2572 qtd->in_process = 1; in dwc2_assign_and_init_hc()
2578 chan->dev_addr = dwc2_hcd_get_dev_addr(&urb->pipe_info); in dwc2_assign_and_init_hc()
2579 chan->ep_num = dwc2_hcd_get_ep_num(&urb->pipe_info); in dwc2_assign_and_init_hc()
2580 chan->speed = qh->dev_speed; in dwc2_assign_and_init_hc()
2581 chan->max_packet = qh->maxp; in dwc2_assign_and_init_hc()
2583 chan->xfer_started = 0; in dwc2_assign_and_init_hc()
2584 chan->halt_status = DWC2_HC_XFER_NO_HALT_STATUS; in dwc2_assign_and_init_hc()
2585 chan->error_state = (qtd->error_count > 0); in dwc2_assign_and_init_hc()
2586 chan->halt_on_queue = 0; in dwc2_assign_and_init_hc()
2587 chan->halt_pending = 0; in dwc2_assign_and_init_hc()
2588 chan->requests = 0; in dwc2_assign_and_init_hc()
2597 chan->ep_is_in = (dwc2_hcd_is_pipe_in(&urb->pipe_info) != 0); in dwc2_assign_and_init_hc()
2598 if (chan->ep_is_in) in dwc2_assign_and_init_hc()
2599 chan->do_ping = 0; in dwc2_assign_and_init_hc()
2601 chan->do_ping = qh->ping_state; in dwc2_assign_and_init_hc()
2603 chan->data_pid_start = qh->data_toggle; in dwc2_assign_and_init_hc()
2604 chan->multi_count = 1; in dwc2_assign_and_init_hc()
2606 if (urb->actual_length > urb->length && in dwc2_assign_and_init_hc()
2607 !dwc2_hcd_is_pipe_in(&urb->pipe_info)) in dwc2_assign_and_init_hc()
2608 urb->actual_length = urb->length; in dwc2_assign_and_init_hc()
2610 if (hsotg->params.host_dma) in dwc2_assign_and_init_hc()
2611 chan->xfer_dma = urb->dma + urb->actual_length; in dwc2_assign_and_init_hc()
2613 chan->xfer_buf = (u8 *)urb->buf + urb->actual_length; in dwc2_assign_and_init_hc()
2615 chan->xfer_len = urb->length - urb->actual_length; in dwc2_assign_and_init_hc()
2616 chan->xfer_count = 0; in dwc2_assign_and_init_hc()
2619 if (qh->do_split) in dwc2_assign_and_init_hc()
2622 chan->do_split = 0; in dwc2_assign_and_init_hc()
2627 /* For non-dword aligned buffers */ in dwc2_assign_and_init_hc()
2628 if (hsotg->params.host_dma && qh->do_split && in dwc2_assign_and_init_hc()
2629 chan->ep_is_in && (chan->xfer_dma & 0x3)) { in dwc2_assign_and_init_hc()
2630 dev_vdbg(hsotg->dev, "Non-aligned buffer\n"); in dwc2_assign_and_init_hc()
2632 dev_err(hsotg->dev, in dwc2_assign_and_init_hc()
2633 "Failed to allocate memory to handle non-aligned buffer\n"); in dwc2_assign_and_init_hc()
2635 chan->align_buf = 0; in dwc2_assign_and_init_hc()
2636 chan->multi_count = 0; in dwc2_assign_and_init_hc()
2637 list_add_tail(&chan->hc_list_entry, in dwc2_assign_and_init_hc()
2638 &hsotg->free_hc_list); in dwc2_assign_and_init_hc()
2639 qtd->in_process = 0; in dwc2_assign_and_init_hc()
2640 qh->channel = NULL; in dwc2_assign_and_init_hc()
2641 return -ENOMEM; in dwc2_assign_and_init_hc()
2645 * We assume that DMA is always aligned in non-split in dwc2_assign_and_init_hc()
2648 WARN_ON_ONCE(hsotg->params.host_dma && in dwc2_assign_and_init_hc()
2649 (chan->xfer_dma & 0x3)); in dwc2_assign_and_init_hc()
2650 chan->align_buf = 0; in dwc2_assign_and_init_hc()
2653 if (chan->ep_type == USB_ENDPOINT_XFER_INT || in dwc2_assign_and_init_hc()
2654 chan->ep_type == USB_ENDPOINT_XFER_ISOC) in dwc2_assign_and_init_hc()
2659 chan->multi_count = qh->maxp_mult; in dwc2_assign_and_init_hc()
2661 if (hsotg->params.dma_desc_enable) { in dwc2_assign_and_init_hc()
2662 chan->desc_list_addr = qh->desc_list_dma; in dwc2_assign_and_init_hc()
2663 chan->desc_list_sz = qh->desc_list_sz; in dwc2_assign_and_init_hc()
2667 chan->qh = qh; in dwc2_assign_and_init_hc()
2673 * dwc2_hcd_select_transactions() - Selects transactions from the HCD transfer
2690 dev_vdbg(hsotg->dev, " Select Transactions\n"); in dwc2_hcd_select_transactions()
2694 qh_ptr = hsotg->periodic_sched_ready.next; in dwc2_hcd_select_transactions()
2695 while (qh_ptr != &hsotg->periodic_sched_ready) { in dwc2_hcd_select_transactions()
2696 if (list_empty(&hsotg->free_hc_list)) in dwc2_hcd_select_transactions()
2698 if (hsotg->params.uframe_sched) { in dwc2_hcd_select_transactions()
2699 if (hsotg->available_host_channels <= 1) in dwc2_hcd_select_transactions()
2701 hsotg->available_host_channels--; in dwc2_hcd_select_transactions()
2705 if (hsotg->params.uframe_sched) in dwc2_hcd_select_transactions()
2706 hsotg->available_host_channels++; in dwc2_hcd_select_transactions()
2714 qh_ptr = qh_ptr->next; in dwc2_hcd_select_transactions()
2715 list_move_tail(&qh->qh_list_entry, in dwc2_hcd_select_transactions()
2716 &hsotg->periodic_sched_assigned); in dwc2_hcd_select_transactions()
2721 * Process entries in the inactive portion of the non-periodic in dwc2_hcd_select_transactions()
2725 num_channels = hsotg->params.host_channels; in dwc2_hcd_select_transactions()
2726 qh_ptr = hsotg->non_periodic_sched_inactive.next; in dwc2_hcd_select_transactions()
2727 while (qh_ptr != &hsotg->non_periodic_sched_inactive) { in dwc2_hcd_select_transactions()
2728 if (!hsotg->params.uframe_sched && in dwc2_hcd_select_transactions()
2729 hsotg->non_periodic_channels >= num_channels - in dwc2_hcd_select_transactions()
2730 hsotg->periodic_channels) in dwc2_hcd_select_transactions()
2732 if (list_empty(&hsotg->free_hc_list)) in dwc2_hcd_select_transactions()
2735 if (hsotg->params.uframe_sched) { in dwc2_hcd_select_transactions()
2736 if (hsotg->available_host_channels < 1) in dwc2_hcd_select_transactions()
2738 hsotg->available_host_channels--; in dwc2_hcd_select_transactions()
2742 if (hsotg->params.uframe_sched) in dwc2_hcd_select_transactions()
2743 hsotg->available_host_channels++; in dwc2_hcd_select_transactions()
2748 * Move the QH from the non-periodic inactive schedule to the in dwc2_hcd_select_transactions()
2749 * non-periodic active schedule in dwc2_hcd_select_transactions()
2751 qh_ptr = qh_ptr->next; in dwc2_hcd_select_transactions()
2752 list_move_tail(&qh->qh_list_entry, in dwc2_hcd_select_transactions()
2753 &hsotg->non_periodic_sched_active); in dwc2_hcd_select_transactions()
2760 if (!hsotg->params.uframe_sched) in dwc2_hcd_select_transactions()
2761 hsotg->non_periodic_channels++; in dwc2_hcd_select_transactions()
2768 * dwc2_queue_transaction() - Attempts to queue a single transaction request for
2769 * a host channel associated with either a periodic or non-periodic transfer
2773 * non-periodic transfer
2775 * for periodic transfers or the non-periodic Tx FIFO
2776 * for non-periodic transfers
2780 * transfer, -1 if there is insufficient space in the Tx FIFO
2783 * request queue. For an OUT transfer or SETUP transaction in Slave mode,
2794 if (chan->do_split) in dwc2_queue_transaction()
2796 list_move_tail(&chan->split_order_list_entry, in dwc2_queue_transaction()
2797 &hsotg->split_order); in dwc2_queue_transaction()
2799 if (hsotg->params.host_dma && chan->qh) { in dwc2_queue_transaction()
2800 if (hsotg->params.dma_desc_enable) { in dwc2_queue_transaction()
2801 if (!chan->xfer_started || in dwc2_queue_transaction()
2802 chan->ep_type == USB_ENDPOINT_XFER_ISOC) { in dwc2_queue_transaction()
2803 dwc2_hcd_start_xfer_ddma(hsotg, chan->qh); in dwc2_queue_transaction()
2804 chan->qh->ping_state = 0; in dwc2_queue_transaction()
2806 } else if (!chan->xfer_started) { in dwc2_queue_transaction()
2808 chan->qh->ping_state = 0; in dwc2_queue_transaction()
2810 } else if (chan->halt_pending) { in dwc2_queue_transaction()
2812 } else if (chan->halt_on_queue) { in dwc2_queue_transaction()
2813 dwc2_hc_halt(hsotg, chan, chan->halt_status); in dwc2_queue_transaction()
2814 } else if (chan->do_ping) { in dwc2_queue_transaction()
2815 if (!chan->xfer_started) in dwc2_queue_transaction()
2817 } else if (!chan->ep_is_in || in dwc2_queue_transaction()
2818 chan->data_pid_start == DWC2_HC_PID_SETUP) { in dwc2_queue_transaction()
2819 if ((fifo_dwords_avail * 4) >= chan->max_packet) { in dwc2_queue_transaction()
2820 if (!chan->xfer_started) { in dwc2_queue_transaction()
2827 retval = -1; in dwc2_queue_transaction()
2830 if (!chan->xfer_started) { in dwc2_queue_transaction()
2863 if (list_empty(&hsotg->periodic_sched_assigned)) in dwc2_process_periodic_channels()
2867 dev_vdbg(hsotg->dev, "Queue periodic transactions\n"); in dwc2_process_periodic_channels()
2876 dev_vdbg(hsotg->dev, " P Tx Req Queue Space Avail (before queue): %d\n", in dwc2_process_periodic_channels()
2878 dev_vdbg(hsotg->dev, " P Tx FIFO Space Avail (before queue): %d\n", in dwc2_process_periodic_channels()
2882 qh_ptr = hsotg->periodic_sched_assigned.next; in dwc2_process_periodic_channels()
2883 while (qh_ptr != &hsotg->periodic_sched_assigned) { in dwc2_process_periodic_channels()
2893 if (!qh->channel) { in dwc2_process_periodic_channels()
2894 qh_ptr = qh_ptr->next; in dwc2_process_periodic_channels()
2899 if (qh->tt_buffer_dirty) { in dwc2_process_periodic_channels()
2900 qh_ptr = qh_ptr->next; in dwc2_process_periodic_channels()
2905 * Set a flag if we're queuing high-bandwidth in slave mode. in dwc2_process_periodic_channels()
2907 * the middle of multiple high-bandwidth packets getting queued. in dwc2_process_periodic_channels()
2909 if (!hsotg->params.host_dma && in dwc2_process_periodic_channels()
2910 qh->channel->multi_count > 1) in dwc2_process_periodic_channels()
2911 hsotg->queuing_high_bandwidth = 1; in dwc2_process_periodic_channels()
2915 status = dwc2_queue_transaction(hsotg, qh->channel, fspcavail); in dwc2_process_periodic_channels()
2922 * In Slave mode, stay on the current transfer until there is in dwc2_process_periodic_channels()
2923 * nothing more to do or the high-bandwidth request count is in dwc2_process_periodic_channels()
2924 * reached. In DMA mode, only need to queue one request. The in dwc2_process_periodic_channels()
2926 * high-bandwidth transfers. in dwc2_process_periodic_channels()
2928 if (hsotg->params.host_dma || status == 0 || in dwc2_process_periodic_channels()
2929 qh->channel->requests == qh->channel->multi_count) { in dwc2_process_periodic_channels()
2930 qh_ptr = qh_ptr->next; in dwc2_process_periodic_channels()
2935 list_move_tail(&qh->qh_list_entry, in dwc2_process_periodic_channels()
2936 &hsotg->periodic_sched_queued); in dwc2_process_periodic_channels()
2939 hsotg->queuing_high_bandwidth = 0; in dwc2_process_periodic_channels()
2945 (!hsotg->params.host_dma && in dwc2_process_periodic_channels()
2946 !list_empty(&hsotg->periodic_sched_assigned))) { in dwc2_process_periodic_channels()
2950 * FIFO empty interrupt. (Always use the half-empty in dwc2_process_periodic_channels()
2961 * Disable the Tx FIFO empty interrupt since there are in dwc2_process_periodic_channels()
2976 * Processes active non-periodic channels and queues transactions for these
2997 dev_vdbg(hsotg->dev, "Queue non-periodic transactions\n"); in dwc2_process_non_periodic_channels()
3004 dev_vdbg(hsotg->dev, " NP Tx Req Queue Space Avail (before queue): %d\n", in dwc2_process_non_periodic_channels()
3006 dev_vdbg(hsotg->dev, " NP Tx FIFO Space Avail (before queue): %d\n", in dwc2_process_non_periodic_channels()
3010 * Keep track of the starting point. Skip over the start-of-list in dwc2_process_non_periodic_channels()
3013 if (hsotg->non_periodic_qh_ptr == &hsotg->non_periodic_sched_active) in dwc2_process_non_periodic_channels()
3014 hsotg->non_periodic_qh_ptr = hsotg->non_periodic_qh_ptr->next; in dwc2_process_non_periodic_channels()
3015 orig_qh_ptr = hsotg->non_periodic_qh_ptr; in dwc2_process_non_periodic_channels()
3025 if (!hsotg->params.host_dma && qspcavail == 0) { in dwc2_process_non_periodic_channels()
3030 qh = list_entry(hsotg->non_periodic_qh_ptr, struct dwc2_qh, in dwc2_process_non_periodic_channels()
3032 if (!qh->channel) in dwc2_process_non_periodic_channels()
3036 if (qh->tt_buffer_dirty) in dwc2_process_non_periodic_channels()
3041 status = dwc2_queue_transaction(hsotg, qh->channel, fspcavail); in dwc2_process_non_periodic_channels()
3050 /* Advance to next QH, skipping start-of-list entry */ in dwc2_process_non_periodic_channels()
3051 hsotg->non_periodic_qh_ptr = hsotg->non_periodic_qh_ptr->next; in dwc2_process_non_periodic_channels()
3052 if (hsotg->non_periodic_qh_ptr == in dwc2_process_non_periodic_channels()
3053 &hsotg->non_periodic_sched_active) in dwc2_process_non_periodic_channels()
3054 hsotg->non_periodic_qh_ptr = in dwc2_process_non_periodic_channels()
3055 hsotg->non_periodic_qh_ptr->next; in dwc2_process_non_periodic_channels()
3056 } while (hsotg->non_periodic_qh_ptr != orig_qh_ptr); in dwc2_process_non_periodic_channels()
3058 if (!hsotg->params.host_dma) { in dwc2_process_non_periodic_channels()
3064 dev_vdbg(hsotg->dev, in dwc2_process_non_periodic_channels()
3067 dev_vdbg(hsotg->dev, in dwc2_process_non_periodic_channels()
3074 * queue or Tx FIFO empties. Enable the non-periodic in dwc2_process_non_periodic_channels()
3075 * Tx FIFO empty interrupt. (Always use the half-empty in dwc2_process_non_periodic_channels()
3084 * Disable the Tx FIFO empty interrupt since there are in dwc2_process_non_periodic_channels()
3098 * dwc2_hcd_queue_transactions() - Processes the currently active host channels
3103 * @tr_type: The type(s) of transactions to queue (non-periodic, periodic,
3112 dev_vdbg(hsotg->dev, "Queue Transactions\n"); in dwc2_hcd_queue_transactions()
3119 /* Process host channels associated with non-periodic transfers */ in dwc2_hcd_queue_transactions()
3122 if (!list_empty(&hsotg->non_periodic_sched_active)) { in dwc2_hcd_queue_transactions()
3127 * there are no non-periodic transfers to process in dwc2_hcd_queue_transactions()
3145 dev_dbg(hsotg->dev, "%s()\n", __func__); in dwc2_conn_id_status_change()
3148 dev_dbg(hsotg->dev, "gotgctl=%0x\n", gotgctl); in dwc2_conn_id_status_change()
3149 dev_dbg(hsotg->dev, "gotgctl.b.conidsts=%d\n", in dwc2_conn_id_status_change()
3152 /* B-Device connector (Device Mode) */ in dwc2_conn_id_status_change()
3155 /* Wait for switch to device mode */ in dwc2_conn_id_status_change()
3156 dev_dbg(hsotg->dev, "connId B\n"); in dwc2_conn_id_status_change()
3157 if (hsotg->bus_suspended) { in dwc2_conn_id_status_change()
3158 dev_info(hsotg->dev, in dwc2_conn_id_status_change()
3159 "Do port resume before switching to device mode\n"); in dwc2_conn_id_status_change()
3163 dev_info(hsotg->dev, in dwc2_conn_id_status_change()
3164 "Waiting for Peripheral Mode, Mode=%s\n", in dwc2_conn_id_status_change()
3170 * check it again and jump to host mode if that was in dwc2_conn_id_status_change()
3180 dev_err(hsotg->dev, in dwc2_conn_id_status_change()
3188 if (hsotg->in_ppd && hsotg->lx_state == DWC2_L2) in dwc2_conn_id_status_change()
3191 hsotg->op_state = OTG_STATE_B_PERIPHERAL; in dwc2_conn_id_status_change()
3194 spin_lock_irqsave(&hsotg->lock, flags); in dwc2_conn_id_status_change()
3196 spin_unlock_irqrestore(&hsotg->lock, flags); in dwc2_conn_id_status_change()
3197 /* Enable ACG feature in device mode,if supported */ in dwc2_conn_id_status_change()
3202 /* A-Device connector (Host Mode) */ in dwc2_conn_id_status_change()
3203 dev_dbg(hsotg->dev, "connId A\n"); in dwc2_conn_id_status_change()
3205 dev_info(hsotg->dev, "Waiting for Host Mode, Mode=%s\n", in dwc2_conn_id_status_change()
3213 dev_err(hsotg->dev, in dwc2_conn_id_status_change()
3216 spin_lock_irqsave(&hsotg->lock, flags); in dwc2_conn_id_status_change()
3218 spin_unlock_irqrestore(&hsotg->lock, flags); in dwc2_conn_id_status_change()
3220 hsotg->op_state = OTG_STATE_A_HOST; in dwc2_conn_id_status_change()
3221 /* Initialize the Core for Host mode */ in dwc2_conn_id_status_change()
3233 dev_dbg(hsotg->dev, "%s()\n", __func__); in dwc2_wakeup_detected()
3240 dev_dbg(hsotg->dev, "Resume: HPRT0=%0x\n", hprt0); in dwc2_wakeup_detected()
3243 dev_dbg(hsotg->dev, "Clear Resume: HPRT0=%0x\n", in dwc2_wakeup_detected()
3247 hsotg->bus_suspended = false; in dwc2_wakeup_detected()
3250 hsotg->lx_state = DWC2_L0; in dwc2_wakeup_detected()
3257 return hcd->self.b_hnp_enable; in dwc2_host_is_b_hnp_enabled()
3261 * dwc2_port_suspend() - Put controller in suspend mode for host.
3266 * Return: non-zero if failed to enter suspend mode for host.
3268 * This function is for entering Host mode suspend.
3278 dev_dbg(hsotg->dev, "%s()\n", __func__); in dwc2_port_suspend()
3280 spin_lock_irqsave(&hsotg->lock, flags); in dwc2_port_suspend()
3282 if (windex == hsotg->otg_port && dwc2_host_is_b_hnp_enabled(hsotg)) { in dwc2_port_suspend()
3286 hsotg->op_state = OTG_STATE_A_SUSPEND; in dwc2_port_suspend()
3289 switch (hsotg->params.power_down) { in dwc2_port_suspend()
3293 dev_err(hsotg->dev, in dwc2_port_suspend()
3301 * hibernation. in dwc2_port_suspend()
3303 spin_unlock_irqrestore(&hsotg->lock, flags); in dwc2_port_suspend()
3306 dev_err(hsotg->dev, "enter hibernation failed.\n"); in dwc2_port_suspend()
3307 spin_lock_irqsave(&hsotg->lock, flags); in dwc2_port_suspend()
3311 * If not hibernation nor partial power down are supported, in dwc2_port_suspend()
3314 if (!hsotg->params.no_clock_gating) in dwc2_port_suspend()
3325 spin_unlock_irqrestore(&hsotg->lock, flags); in dwc2_port_suspend()
3329 spin_unlock_irqrestore(&hsotg->lock, flags); in dwc2_port_suspend()
3336 * dwc2_port_resume() - Exit controller from suspend mode for host.
3340 * Return: non-zero if failed to exit suspend mode for host.
3342 * This function is for exiting Host mode suspend.
3350 spin_lock_irqsave(&hsotg->lock, flags); in dwc2_port_resume()
3352 switch (hsotg->params.power_down) { in dwc2_port_resume()
3356 dev_err(hsotg->dev, in dwc2_port_resume()
3360 /* Exit host hibernation. */ in dwc2_port_resume()
3363 dev_err(hsotg->dev, "exit hibernation failed.\n"); in dwc2_port_resume()
3367 * If not hibernation nor partial power down are supported, in dwc2_port_resume()
3370 spin_unlock_irqrestore(&hsotg->lock, flags); in dwc2_port_resume()
3372 spin_lock_irqsave(&hsotg->lock, flags); in dwc2_port_resume()
3376 spin_unlock_irqrestore(&hsotg->lock, flags); in dwc2_port_resume()
3381 /* Handles hub class-specific requests */
3395 dev_dbg(hsotg->dev, "ClearHubFeature %1xh\n", wvalue); in dwc2_hcd_hub_control()
3404 retval = -EINVAL; in dwc2_hcd_hub_control()
3405 dev_err(hsotg->dev, in dwc2_hcd_hub_control()
3417 dev_dbg(hsotg->dev, in dwc2_hcd_hub_control()
3425 dev_dbg(hsotg->dev, in dwc2_hcd_hub_control()
3428 if (hsotg->bus_suspended) in dwc2_hcd_hub_control()
3433 dev_dbg(hsotg->dev, in dwc2_hcd_hub_control()
3444 dev_dbg(hsotg->dev, in dwc2_hcd_hub_control()
3453 dev_dbg(hsotg->dev, in dwc2_hcd_hub_control()
3455 hsotg->flags.b.port_connect_status_change = 0; in dwc2_hcd_hub_control()
3460 dev_dbg(hsotg->dev, in dwc2_hcd_hub_control()
3462 hsotg->flags.b.port_reset_change = 0; in dwc2_hcd_hub_control()
3467 * Clears the driver's internal Port Enable/Disable in dwc2_hcd_hub_control()
3470 dev_dbg(hsotg->dev, in dwc2_hcd_hub_control()
3472 hsotg->flags.b.port_enable_change = 0; in dwc2_hcd_hub_control()
3481 dev_dbg(hsotg->dev, in dwc2_hcd_hub_control()
3483 hsotg->flags.b.port_suspend_change = 0; in dwc2_hcd_hub_control()
3487 dev_dbg(hsotg->dev, in dwc2_hcd_hub_control()
3489 hsotg->flags.b.port_l1_change = 0; in dwc2_hcd_hub_control()
3493 dev_dbg(hsotg->dev, in dwc2_hcd_hub_control()
3495 hsotg->flags.b.port_over_current_change = 0; in dwc2_hcd_hub_control()
3499 retval = -EINVAL; in dwc2_hcd_hub_control()
3500 dev_err(hsotg->dev, in dwc2_hcd_hub_control()
3507 dev_dbg(hsotg->dev, "GetHubDescriptor\n"); in dwc2_hcd_hub_control()
3509 hub_desc->bDescLength = 9; in dwc2_hcd_hub_control()
3510 hub_desc->bDescriptorType = USB_DT_HUB; in dwc2_hcd_hub_control()
3511 hub_desc->bNbrPorts = 1; in dwc2_hcd_hub_control()
3512 hub_desc->wHubCharacteristics = in dwc2_hcd_hub_control()
3515 hub_desc->bPwrOn2PwrGood = 1; in dwc2_hcd_hub_control()
3516 hub_desc->bHubContrCurrent = 0; in dwc2_hcd_hub_control()
3517 hub_desc->u.hs.DeviceRemovable[0] = 0; in dwc2_hcd_hub_control()
3518 hub_desc->u.hs.DeviceRemovable[1] = 0xff; in dwc2_hcd_hub_control()
3522 dev_dbg(hsotg->dev, "GetHubStatus\n"); in dwc2_hcd_hub_control()
3527 dev_vdbg(hsotg->dev, in dwc2_hcd_hub_control()
3529 hsotg->flags.d32); in dwc2_hcd_hub_control()
3534 if (hsotg->flags.b.port_connect_status_change) in dwc2_hcd_hub_control()
3536 if (hsotg->flags.b.port_enable_change) in dwc2_hcd_hub_control()
3538 if (hsotg->flags.b.port_suspend_change) in dwc2_hcd_hub_control()
3540 if (hsotg->flags.b.port_l1_change) in dwc2_hcd_hub_control()
3542 if (hsotg->flags.b.port_reset_change) in dwc2_hcd_hub_control()
3544 if (hsotg->flags.b.port_over_current_change) { in dwc2_hcd_hub_control()
3545 dev_warn(hsotg->dev, "Overcurrent change detected\n"); in dwc2_hcd_hub_control()
3549 if (!hsotg->flags.b.port_connect_status) { in dwc2_hcd_hub_control()
3552 * either in device mode or it soon will be. Just in dwc2_hcd_hub_control()
3555 * is in device mode. in dwc2_hcd_hub_control()
3562 dev_vdbg(hsotg->dev, " HPRT0: 0x%08x\n", hprt0); in dwc2_hcd_hub_control()
3587 if (hsotg->params.dma_desc_fs_enable) { in dwc2_hcd_hub_control()
3592 if (hsotg->new_connection && in dwc2_hcd_hub_control()
3600 dev_info(hsotg->dev, "Enabling descriptor DMA mode\n"); in dwc2_hcd_hub_control()
3601 hsotg->params.dma_desc_enable = true; in dwc2_hcd_hub_control()
3605 hsotg->new_connection = false; in dwc2_hcd_hub_control()
3609 dev_vdbg(hsotg->dev, "port_status=%08x\n", port_status); in dwc2_hcd_hub_control()
3614 dev_dbg(hsotg->dev, "SetHubFeature\n"); in dwc2_hcd_hub_control()
3619 dev_dbg(hsotg->dev, "SetPortFeature\n"); in dwc2_hcd_hub_control()
3623 if (!hsotg->flags.b.port_connect_status) { in dwc2_hcd_hub_control()
3626 * either in device mode or it soon will be. Just in dwc2_hcd_hub_control()
3629 * mode. in dwc2_hcd_hub_control()
3636 dev_dbg(hsotg->dev, in dwc2_hcd_hub_control()
3637 "SetPortFeature - USB_PORT_FEAT_SUSPEND\n"); in dwc2_hcd_hub_control()
3638 if (windex != hsotg->otg_port) in dwc2_hcd_hub_control()
3640 if (!hsotg->bus_suspended) in dwc2_hcd_hub_control()
3645 dev_dbg(hsotg->dev, in dwc2_hcd_hub_control()
3646 "SetPortFeature - USB_PORT_FEAT_POWER\n"); in dwc2_hcd_hub_control()
3656 dev_dbg(hsotg->dev, in dwc2_hcd_hub_control()
3657 "SetPortFeature - USB_PORT_FEAT_RESET\n"); in dwc2_hcd_hub_control()
3661 if (hsotg->hibernated) { in dwc2_hcd_hub_control()
3664 dev_err(hsotg->dev, in dwc2_hcd_hub_control()
3665 "exit hibernation failed\n"); in dwc2_hcd_hub_control()
3668 if (hsotg->in_ppd) { in dwc2_hcd_hub_control()
3672 dev_err(hsotg->dev, in dwc2_hcd_hub_control()
3676 if (hsotg->params.power_down == in dwc2_hcd_hub_control()
3677 DWC2_POWER_DOWN_PARAM_NONE && hsotg->bus_suspended) in dwc2_hcd_hub_control()
3692 * When B-Host the Port reset bit is set in the Start in dwc2_hcd_hub_control()
3698 dev_dbg(hsotg->dev, in dwc2_hcd_hub_control()
3699 "In host mode, hprt0=%08x\n", hprt0); in dwc2_hcd_hub_control()
3709 hsotg->lx_state = DWC2_L0; /* Now back to On state */ in dwc2_hcd_hub_control()
3713 dev_dbg(hsotg->dev, in dwc2_hcd_hub_control()
3714 "SetPortFeature - USB_PORT_FEAT_INDICATOR\n"); in dwc2_hcd_hub_control()
3720 dev_dbg(hsotg->dev, in dwc2_hcd_hub_control()
3721 "SetPortFeature - USB_PORT_FEAT_TEST\n"); in dwc2_hcd_hub_control()
3728 retval = -EINVAL; in dwc2_hcd_hub_control()
3729 dev_err(hsotg->dev, in dwc2_hcd_hub_control()
3738 retval = -EINVAL; in dwc2_hcd_hub_control()
3739 dev_dbg(hsotg->dev, in dwc2_hcd_hub_control()
3753 return -EINVAL; in dwc2_hcd_is_status_changed()
3755 retval = (hsotg->flags.b.port_connect_status_change || in dwc2_hcd_is_status_changed()
3756 hsotg->flags.b.port_reset_change || in dwc2_hcd_is_status_changed()
3757 hsotg->flags.b.port_enable_change || in dwc2_hcd_is_status_changed()
3758 hsotg->flags.b.port_suspend_change || in dwc2_hcd_is_status_changed()
3759 hsotg->flags.b.port_over_current_change); in dwc2_hcd_is_status_changed()
3762 dev_dbg(hsotg->dev, in dwc2_hcd_is_status_changed()
3764 dev_dbg(hsotg->dev, " port_connect_status_change: %d\n", in dwc2_hcd_is_status_changed()
3765 hsotg->flags.b.port_connect_status_change); in dwc2_hcd_is_status_changed()
3766 dev_dbg(hsotg->dev, " port_reset_change: %d\n", in dwc2_hcd_is_status_changed()
3767 hsotg->flags.b.port_reset_change); in dwc2_hcd_is_status_changed()
3768 dev_dbg(hsotg->dev, " port_enable_change: %d\n", in dwc2_hcd_is_status_changed()
3769 hsotg->flags.b.port_enable_change); in dwc2_hcd_is_status_changed()
3770 dev_dbg(hsotg->dev, " port_suspend_change: %d\n", in dwc2_hcd_is_status_changed()
3771 hsotg->flags.b.port_suspend_change); in dwc2_hcd_is_status_changed()
3772 dev_dbg(hsotg->dev, " port_over_current_change: %d\n", in dwc2_hcd_is_status_changed()
3773 hsotg->flags.b.port_over_current_change); in dwc2_hcd_is_status_changed()
3784 dev_vdbg(hsotg->dev, "DWC OTG HCD GET FRAME NUMBER %d\n", in dwc2_hcd_get_frame_number()
3813 phy_clks = (interval - remaining) + in dwc2_hcd_get_future_frame_number()
3821 return hsotg->op_state == OTG_STATE_B_HOST; in dwc2_hcd_is_b_host()
3832 urb->packet_count = iso_desc_count; in dwc2_hcd_urb_alloc()
3844 dev_vdbg(hsotg->dev, in dwc2_hcd_urb_set_pipeinfo()
3847 urb->pipe_info.dev_addr = dev_addr; in dwc2_hcd_urb_set_pipeinfo()
3848 urb->pipe_info.ep_num = ep_num; in dwc2_hcd_urb_set_pipeinfo()
3849 urb->pipe_info.pipe_type = ep_type; in dwc2_hcd_urb_set_pipeinfo()
3850 urb->pipe_info.pipe_dir = ep_dir; in dwc2_hcd_urb_set_pipeinfo()
3851 urb->pipe_info.maxp = maxp; in dwc2_hcd_urb_set_pipeinfo()
3852 urb->pipe_info.maxp_mult = maxp_mult; in dwc2_hcd_urb_set_pipeinfo()
3870 num_channels = hsotg->params.host_channels; in dwc2_hcd_dump_state()
3871 dev_dbg(hsotg->dev, "\n"); in dwc2_hcd_dump_state()
3872 dev_dbg(hsotg->dev, in dwc2_hcd_dump_state()
3874 dev_dbg(hsotg->dev, "HCD State:\n"); in dwc2_hcd_dump_state()
3875 dev_dbg(hsotg->dev, " Num channels: %d\n", num_channels); in dwc2_hcd_dump_state()
3878 chan = hsotg->hc_ptr_array[i]; in dwc2_hcd_dump_state()
3879 dev_dbg(hsotg->dev, " Channel %d:\n", i); in dwc2_hcd_dump_state()
3880 dev_dbg(hsotg->dev, in dwc2_hcd_dump_state()
3882 chan->dev_addr, chan->ep_num, chan->ep_is_in); in dwc2_hcd_dump_state()
3883 dev_dbg(hsotg->dev, " speed: %d\n", chan->speed); in dwc2_hcd_dump_state()
3884 dev_dbg(hsotg->dev, " ep_type: %d\n", chan->ep_type); in dwc2_hcd_dump_state()
3885 dev_dbg(hsotg->dev, " max_packet: %d\n", chan->max_packet); in dwc2_hcd_dump_state()
3886 dev_dbg(hsotg->dev, " data_pid_start: %d\n", in dwc2_hcd_dump_state()
3887 chan->data_pid_start); in dwc2_hcd_dump_state()
3888 dev_dbg(hsotg->dev, " multi_count: %d\n", chan->multi_count); in dwc2_hcd_dump_state()
3889 dev_dbg(hsotg->dev, " xfer_started: %d\n", in dwc2_hcd_dump_state()
3890 chan->xfer_started); in dwc2_hcd_dump_state()
3891 dev_dbg(hsotg->dev, " xfer_buf: %p\n", chan->xfer_buf); in dwc2_hcd_dump_state()
3892 dev_dbg(hsotg->dev, " xfer_dma: %08lx\n", in dwc2_hcd_dump_state()
3893 (unsigned long)chan->xfer_dma); in dwc2_hcd_dump_state()
3894 dev_dbg(hsotg->dev, " xfer_len: %d\n", chan->xfer_len); in dwc2_hcd_dump_state()
3895 dev_dbg(hsotg->dev, " xfer_count: %d\n", chan->xfer_count); in dwc2_hcd_dump_state()
3896 dev_dbg(hsotg->dev, " halt_on_queue: %d\n", in dwc2_hcd_dump_state()
3897 chan->halt_on_queue); in dwc2_hcd_dump_state()
3898 dev_dbg(hsotg->dev, " halt_pending: %d\n", in dwc2_hcd_dump_state()
3899 chan->halt_pending); in dwc2_hcd_dump_state()
3900 dev_dbg(hsotg->dev, " halt_status: %d\n", chan->halt_status); in dwc2_hcd_dump_state()
3901 dev_dbg(hsotg->dev, " do_split: %d\n", chan->do_split); in dwc2_hcd_dump_state()
3902 dev_dbg(hsotg->dev, " complete_split: %d\n", in dwc2_hcd_dump_state()
3903 chan->complete_split); in dwc2_hcd_dump_state()
3904 dev_dbg(hsotg->dev, " hub_addr: %d\n", chan->hub_addr); in dwc2_hcd_dump_state()
3905 dev_dbg(hsotg->dev, " hub_port: %d\n", chan->hub_port); in dwc2_hcd_dump_state()
3906 dev_dbg(hsotg->dev, " xact_pos: %d\n", chan->xact_pos); in dwc2_hcd_dump_state()
3907 dev_dbg(hsotg->dev, " requests: %d\n", chan->requests); in dwc2_hcd_dump_state()
3908 dev_dbg(hsotg->dev, " qh: %p\n", chan->qh); in dwc2_hcd_dump_state()
3910 if (chan->xfer_started) { in dwc2_hcd_dump_state()
3918 dev_dbg(hsotg->dev, " hfnum: 0x%08x\n", hfnum); in dwc2_hcd_dump_state()
3919 dev_dbg(hsotg->dev, " hcchar: 0x%08x\n", hcchar); in dwc2_hcd_dump_state()
3920 dev_dbg(hsotg->dev, " hctsiz: 0x%08x\n", hctsiz); in dwc2_hcd_dump_state()
3921 dev_dbg(hsotg->dev, " hcint: 0x%08x\n", hcint); in dwc2_hcd_dump_state()
3922 dev_dbg(hsotg->dev, " hcintmsk: 0x%08x\n", hcintmsk); in dwc2_hcd_dump_state()
3925 if (!(chan->xfer_started && chan->qh)) in dwc2_hcd_dump_state()
3928 list_for_each_entry(qtd, &chan->qh->qtd_list, qtd_list_entry) { in dwc2_hcd_dump_state()
3929 if (!qtd->in_process) in dwc2_hcd_dump_state()
3931 urb = qtd->urb; in dwc2_hcd_dump_state()
3932 dev_dbg(hsotg->dev, " URB Info:\n"); in dwc2_hcd_dump_state()
3933 dev_dbg(hsotg->dev, " qtd: %p, urb: %p\n", in dwc2_hcd_dump_state()
3936 dev_dbg(hsotg->dev, in dwc2_hcd_dump_state()
3938 dwc2_hcd_get_dev_addr(&urb->pipe_info), in dwc2_hcd_dump_state()
3939 dwc2_hcd_get_ep_num(&urb->pipe_info), in dwc2_hcd_dump_state()
3940 dwc2_hcd_is_pipe_in(&urb->pipe_info) ? in dwc2_hcd_dump_state()
3942 dev_dbg(hsotg->dev, in dwc2_hcd_dump_state()
3944 dwc2_hcd_get_maxp(&urb->pipe_info), in dwc2_hcd_dump_state()
3945 dwc2_hcd_get_maxp_mult(&urb->pipe_info)); in dwc2_hcd_dump_state()
3946 dev_dbg(hsotg->dev, in dwc2_hcd_dump_state()
3948 urb->buf); in dwc2_hcd_dump_state()
3949 dev_dbg(hsotg->dev, in dwc2_hcd_dump_state()
3951 (unsigned long)urb->dma); in dwc2_hcd_dump_state()
3952 dev_dbg(hsotg->dev, in dwc2_hcd_dump_state()
3954 urb->length); in dwc2_hcd_dump_state()
3955 dev_dbg(hsotg->dev, " actual_length: %d\n", in dwc2_hcd_dump_state()
3956 urb->actual_length); in dwc2_hcd_dump_state()
3961 dev_dbg(hsotg->dev, " non_periodic_channels: %d\n", in dwc2_hcd_dump_state()
3962 hsotg->non_periodic_channels); in dwc2_hcd_dump_state()
3963 dev_dbg(hsotg->dev, " periodic_channels: %d\n", in dwc2_hcd_dump_state()
3964 hsotg->periodic_channels); in dwc2_hcd_dump_state()
3965 dev_dbg(hsotg->dev, " periodic_usecs: %d\n", hsotg->periodic_usecs); in dwc2_hcd_dump_state()
3967 dev_dbg(hsotg->dev, " NP Tx Req Queue Space Avail: %d\n", in dwc2_hcd_dump_state()
3969 dev_dbg(hsotg->dev, " NP Tx FIFO Space Avail: %d\n", in dwc2_hcd_dump_state()
3972 dev_dbg(hsotg->dev, " P Tx Req Queue Space Avail: %d\n", in dwc2_hcd_dump_state()
3974 dev_dbg(hsotg->dev, " P Tx FIFO Space Avail: %d\n", in dwc2_hcd_dump_state()
3978 dev_dbg(hsotg->dev, in dwc2_hcd_dump_state()
3980 dev_dbg(hsotg->dev, "\n"); in dwc2_hcd_dump_state()
3993 p = (struct wrapper_priv_data *)&hcd->hcd_priv; in dwc2_hcd_to_hsotg()
3994 return p->hsotg; in dwc2_hcd_to_hsotg()
3998 * dwc2_host_get_tt_info() - Get the dwc2_tt associated with context
4023 if (urb->dev->tt) { in dwc2_host_get_tt_info()
4024 *ttport = urb->dev->ttport; in dwc2_host_get_tt_info()
4026 dwc_tt = urb->dev->tt->hcpriv; in dwc2_host_get_tt_info()
4035 sizeof(dwc_tt->periodic_bitmaps[0]); in dwc2_host_get_tt_info()
4036 if (urb->dev->tt->multi) in dwc2_host_get_tt_info()
4037 bitmap_size *= urb->dev->tt->hub->maxchild; in dwc2_host_get_tt_info()
4044 dwc_tt->usb_tt = urb->dev->tt; in dwc2_host_get_tt_info()
4045 dwc_tt->usb_tt->hcpriv = dwc_tt; in dwc2_host_get_tt_info()
4048 dwc_tt->refcount++; in dwc2_host_get_tt_info()
4055 * dwc2_host_put_tt_info() - Put the dwc2_tt from dwc2_host_get_tt_info()
4067 /* Model kfree and make put of NULL a no-op */ in dwc2_host_put_tt_info()
4071 WARN_ON(dwc_tt->refcount < 1); in dwc2_host_put_tt_info()
4073 dwc_tt->refcount--; in dwc2_host_put_tt_info()
4074 if (!dwc_tt->refcount) { in dwc2_host_put_tt_info()
4075 dwc_tt->usb_tt->hcpriv = NULL; in dwc2_host_put_tt_info()
4084 return urb->dev->speed; in dwc2_host_get_speed()
4092 if (urb->interval) in dwc2_allocate_bus_bandwidth()
4093 bus->bandwidth_allocated += bw / urb->interval; in dwc2_allocate_bus_bandwidth()
4094 if (usb_pipetype(urb->pipe) == PIPE_ISOCHRONOUS) in dwc2_allocate_bus_bandwidth()
4095 bus->bandwidth_isoc_reqs++; in dwc2_allocate_bus_bandwidth()
4097 bus->bandwidth_int_reqs++; in dwc2_allocate_bus_bandwidth()
4105 if (urb->interval) in dwc2_free_bus_bandwidth()
4106 bus->bandwidth_allocated -= bw / urb->interval; in dwc2_free_bus_bandwidth()
4107 if (usb_pipetype(urb->pipe) == PIPE_ISOCHRONOUS) in dwc2_free_bus_bandwidth()
4108 bus->bandwidth_isoc_reqs--; in dwc2_free_bus_bandwidth()
4110 bus->bandwidth_int_reqs--; in dwc2_free_bus_bandwidth()
4126 dev_dbg(hsotg->dev, "## %s: qtd is NULL ##\n", __func__); in dwc2_host_complete()
4130 if (!qtd->urb) { in dwc2_host_complete()
4131 dev_dbg(hsotg->dev, "## %s: qtd->urb is NULL ##\n", __func__); in dwc2_host_complete()
4135 urb = qtd->urb->priv; in dwc2_host_complete()
4137 dev_dbg(hsotg->dev, "## %s: urb->priv is NULL ##\n", __func__); in dwc2_host_complete()
4141 urb->actual_length = dwc2_hcd_urb_get_actual_length(qtd->urb); in dwc2_host_complete()
4144 dev_vdbg(hsotg->dev, in dwc2_host_complete()
4145 "%s: urb %p device %d ep %d-%s status %d actual %d\n", in dwc2_host_complete()
4146 __func__, urb, usb_pipedevice(urb->pipe), in dwc2_host_complete()
4147 usb_pipeendpoint(urb->pipe), in dwc2_host_complete()
4148 usb_pipein(urb->pipe) ? "IN" : "OUT", status, in dwc2_host_complete()
4149 urb->actual_length); in dwc2_host_complete()
4151 if (usb_pipetype(urb->pipe) == PIPE_ISOCHRONOUS) { in dwc2_host_complete()
4152 if (!hsotg->params.dma_desc_enable) in dwc2_host_complete()
4153 urb->start_frame = qtd->qh->start_active_frame; in dwc2_host_complete()
4154 urb->error_count = dwc2_hcd_urb_get_error_count(qtd->urb); in dwc2_host_complete()
4155 for (i = 0; i < urb->number_of_packets; ++i) { in dwc2_host_complete()
4156 urb->iso_frame_desc[i].actual_length = in dwc2_host_complete()
4158 qtd->urb, i); in dwc2_host_complete()
4159 urb->iso_frame_desc[i].status = in dwc2_host_complete()
4160 dwc2_hcd_urb_get_iso_desc_status(qtd->urb, i); in dwc2_host_complete()
4164 if (usb_pipetype(urb->pipe) == PIPE_ISOCHRONOUS && dbg_perio()) { in dwc2_host_complete()
4165 for (i = 0; i < urb->number_of_packets; i++) in dwc2_host_complete()
4166 dev_vdbg(hsotg->dev, " ISO Desc %d status %d\n", in dwc2_host_complete()
4167 i, urb->iso_frame_desc[i].status); in dwc2_host_complete()
4170 urb->status = status; in dwc2_host_complete()
4172 if ((urb->transfer_flags & URB_SHORT_NOT_OK) && in dwc2_host_complete()
4173 urb->actual_length < urb->transfer_buffer_length) in dwc2_host_complete()
4174 urb->status = -EREMOTEIO; in dwc2_host_complete()
4177 if (usb_pipetype(urb->pipe) == PIPE_ISOCHRONOUS || in dwc2_host_complete()
4178 usb_pipetype(urb->pipe) == PIPE_INTERRUPT) { in dwc2_host_complete()
4179 struct usb_host_endpoint *ep = urb->ep; in dwc2_host_complete()
4188 urb->hcpriv = NULL; in dwc2_host_complete()
4189 kfree(qtd->urb); in dwc2_host_complete()
4190 qtd->urb = NULL; in dwc2_host_complete()
4196 * Work queue function for starting the HCD when A-Cable is connected
4203 dev_dbg(hsotg->dev, "%s() %p\n", __func__, hsotg); in dwc2_hcd_start_func()
4217 dev_dbg(hsotg->dev, "USB RESET function called\n"); in dwc2_hcd_reset_func()
4219 spin_lock_irqsave(&hsotg->lock, flags); in dwc2_hcd_reset_func()
4224 hsotg->flags.b.port_reset_change = 1; in dwc2_hcd_reset_func()
4226 spin_unlock_irqrestore(&hsotg->lock, flags); in dwc2_hcd_reset_func()
4235 ret = phy_reset(hsotg->phy); in dwc2_hcd_phy_reset_func()
4237 dev_warn(hsotg->dev, "PHY reset failed\n"); in dwc2_hcd_phy_reset_func()
4248 * mode operation. Activates the root port. Returns 0 on success and a negative
4259 dev_dbg(hsotg->dev, "DWC OTG HCD START\n"); in _dwc2_hcd_start()
4261 spin_lock_irqsave(&hsotg->lock, flags); in _dwc2_hcd_start()
4262 hsotg->lx_state = DWC2_L0; in _dwc2_hcd_start()
4263 hcd->state = HC_STATE_RUNNING; in _dwc2_hcd_start()
4264 set_bit(HCD_FLAG_HW_ACCESSIBLE, &hcd->flags); in _dwc2_hcd_start()
4267 spin_unlock_irqrestore(&hsotg->lock, flags); in _dwc2_hcd_start()
4277 spin_unlock_irqrestore(&hsotg->lock, flags); in _dwc2_hcd_start()
4281 spin_lock_irqsave(&hsotg->lock, flags); in _dwc2_hcd_start()
4285 if (bus->root_hub) { in _dwc2_hcd_start()
4286 dev_dbg(hsotg->dev, "DWC OTG HCD Has Root Hub\n"); in _dwc2_hcd_start()
4291 spin_unlock_irqrestore(&hsotg->lock, flags); in _dwc2_hcd_start()
4297 * Halts the DWC_otg host mode operations in a clean manner. USB transfers are
4306 /* Turn off all host-specific interrupts */ in _dwc2_hcd_stop()
4310 synchronize_irq(hcd->irq); in _dwc2_hcd_stop()
4312 spin_lock_irqsave(&hsotg->lock, flags); in _dwc2_hcd_stop()
4317 hsotg->lx_state = DWC2_L3; in _dwc2_hcd_stop()
4318 hcd->state = HC_STATE_HALT; in _dwc2_hcd_stop()
4319 clear_bit(HCD_FLAG_HW_ACCESSIBLE, &hcd->flags); in _dwc2_hcd_stop()
4320 spin_unlock_irqrestore(&hsotg->lock, flags); in _dwc2_hcd_stop()
4335 spin_lock_irqsave(&hsotg->lock, flags); in _dwc2_hcd_suspend()
4340 if (hsotg->lx_state != DWC2_L0) in _dwc2_hcd_suspend()
4346 if (hsotg->op_state == OTG_STATE_B_PERIPHERAL) in _dwc2_hcd_suspend()
4349 if (hsotg->bus_suspended) in _dwc2_hcd_suspend()
4352 if (hsotg->flags.b.port_connect_status == 0) in _dwc2_hcd_suspend()
4355 switch (hsotg->params.power_down) { in _dwc2_hcd_suspend()
4360 dev_err(hsotg->dev, in _dwc2_hcd_suspend()
4363 clear_bit(HCD_FLAG_HW_ACCESSIBLE, &hcd->flags); in _dwc2_hcd_suspend()
4366 /* Enter hibernation */ in _dwc2_hcd_suspend()
4367 spin_unlock_irqrestore(&hsotg->lock, flags); in _dwc2_hcd_suspend()
4370 dev_err(hsotg->dev, "enter hibernation failed\n"); in _dwc2_hcd_suspend()
4371 spin_lock_irqsave(&hsotg->lock, flags); in _dwc2_hcd_suspend()
4374 clear_bit(HCD_FLAG_HW_ACCESSIBLE, &hcd->flags); in _dwc2_hcd_suspend()
4378 * If not hibernation nor partial power down are supported, in _dwc2_hcd_suspend()
4381 if (!hsotg->params.no_clock_gating) { in _dwc2_hcd_suspend()
4385 clear_bit(HCD_FLAG_HW_ACCESSIBLE, &hcd->flags); in _dwc2_hcd_suspend()
4392 spin_unlock_irqrestore(&hsotg->lock, flags); in _dwc2_hcd_suspend()
4394 spin_lock_irqsave(&hsotg->lock, flags); in _dwc2_hcd_suspend()
4397 if (!IS_ERR_OR_NULL(hsotg->uphy)) { in _dwc2_hcd_suspend()
4398 spin_unlock_irqrestore(&hsotg->lock, flags); in _dwc2_hcd_suspend()
4399 usb_phy_set_suspend(hsotg->uphy, true); in _dwc2_hcd_suspend()
4400 spin_lock_irqsave(&hsotg->lock, flags); in _dwc2_hcd_suspend()
4404 hsotg->lx_state = DWC2_L2; in _dwc2_hcd_suspend()
4406 spin_unlock_irqrestore(&hsotg->lock, flags); in _dwc2_hcd_suspend()
4418 spin_lock_irqsave(&hsotg->lock, flags); in _dwc2_hcd_resume()
4423 if (hsotg->lx_state != DWC2_L2) in _dwc2_hcd_resume()
4430 * Partial Power Down mode from _dwc2_hcd_resume() if not in Partial in _dwc2_hcd_resume()
4431 * Power Down mode. in _dwc2_hcd_resume()
4434 hsotg->lx_state = DWC2_L0; in _dwc2_hcd_resume()
4438 switch (hsotg->params.power_down) { in _dwc2_hcd_resume()
4442 dev_err(hsotg->dev, in _dwc2_hcd_resume()
4448 set_bit(HCD_FLAG_HW_ACCESSIBLE, &hcd->flags); in _dwc2_hcd_resume()
4453 dev_err(hsotg->dev, "exit hibernation failed.\n"); in _dwc2_hcd_resume()
4459 set_bit(HCD_FLAG_HW_ACCESSIBLE, &hcd->flags); in _dwc2_hcd_resume()
4463 * If not hibernation nor partial power down are supported, in _dwc2_hcd_resume()
4466 spin_unlock_irqrestore(&hsotg->lock, flags); in _dwc2_hcd_resume()
4470 * Initialize the Core for Host mode, as after system resume in _dwc2_hcd_resume()
4476 spin_lock_irqsave(&hsotg->lock, flags); in _dwc2_hcd_resume()
4482 set_bit(HCD_FLAG_HW_ACCESSIBLE, &hcd->flags); in _dwc2_hcd_resume()
4485 hsotg->lx_state = DWC2_L0; in _dwc2_hcd_resume()
4490 hsotg->flags.b.port_suspend_change = 1; in _dwc2_hcd_resume()
4497 if (!IS_ERR_OR_NULL(hsotg->uphy)) { in _dwc2_hcd_resume()
4498 spin_unlock_irqrestore(&hsotg->lock, flags); in _dwc2_hcd_resume()
4499 usb_phy_set_suspend(hsotg->uphy, false); in _dwc2_hcd_resume()
4500 spin_lock_irqsave(&hsotg->lock, flags); in _dwc2_hcd_resume()
4504 spin_unlock_irqrestore(&hsotg->lock, flags); in _dwc2_hcd_resume()
4507 /* Wait for controller to correctly update D+/D- level */ in _dwc2_hcd_resume()
4509 spin_lock_irqsave(&hsotg->lock, flags); in _dwc2_hcd_resume()
4519 spin_unlock_irqrestore(&hsotg->lock, flags); in _dwc2_hcd_resume()
4521 spin_lock_irqsave(&hsotg->lock, flags); in _dwc2_hcd_resume()
4523 spin_unlock_irqrestore(&hsotg->lock, flags); in _dwc2_hcd_resume()
4544 dev_vdbg(hsotg->dev, "%s, urb %p\n", fn_name, urb); in dwc2_dump_urb_info()
4545 dev_vdbg(hsotg->dev, " Device address: %d\n", in dwc2_dump_urb_info()
4546 usb_pipedevice(urb->pipe)); in dwc2_dump_urb_info()
4547 dev_vdbg(hsotg->dev, " Endpoint: %d, %s\n", in dwc2_dump_urb_info()
4548 usb_pipeendpoint(urb->pipe), in dwc2_dump_urb_info()
4549 usb_pipein(urb->pipe) ? "IN" : "OUT"); in dwc2_dump_urb_info()
4551 switch (usb_pipetype(urb->pipe)) { in dwc2_dump_urb_info()
4566 dev_vdbg(hsotg->dev, " Endpoint type: %s %s (%s)\n", pipetype, in dwc2_dump_urb_info()
4567 usb_urb_dir_in(urb) ? "IN" : "OUT", usb_pipein(urb->pipe) ? in dwc2_dump_urb_info()
4570 switch (urb->dev->speed) { in dwc2_dump_urb_info()
4585 dev_vdbg(hsotg->dev, " Speed: %s\n", speed); in dwc2_dump_urb_info()
4586 dev_vdbg(hsotg->dev, " Max packet size: %d (%d mult)\n", in dwc2_dump_urb_info()
4587 usb_endpoint_maxp(&urb->ep->desc), in dwc2_dump_urb_info()
4588 usb_endpoint_maxp_mult(&urb->ep->desc)); in dwc2_dump_urb_info()
4590 dev_vdbg(hsotg->dev, " Data buffer length: %d\n", in dwc2_dump_urb_info()
4591 urb->transfer_buffer_length); in dwc2_dump_urb_info()
4592 dev_vdbg(hsotg->dev, " Transfer buffer: %p, Transfer DMA: %08lx\n", in dwc2_dump_urb_info()
4593 urb->transfer_buffer, (unsigned long)urb->transfer_dma); in dwc2_dump_urb_info()
4594 dev_vdbg(hsotg->dev, " Setup buffer: %p, Setup DMA: %08lx\n", in dwc2_dump_urb_info()
4595 urb->setup_packet, (unsigned long)urb->setup_dma); in dwc2_dump_urb_info()
4596 dev_vdbg(hsotg->dev, " Interval: %d\n", urb->interval); in dwc2_dump_urb_info()
4598 if (usb_pipetype(urb->pipe) == PIPE_ISOCHRONOUS) { in dwc2_dump_urb_info()
4601 for (i = 0; i < urb->number_of_packets; i++) { in dwc2_dump_urb_info()
4602 dev_vdbg(hsotg->dev, " ISO Desc %d:\n", i); in dwc2_dump_urb_info()
4603 dev_vdbg(hsotg->dev, " offset: %d, length %d\n", in dwc2_dump_urb_info()
4604 urb->iso_frame_desc[i].offset, in dwc2_dump_urb_info()
4605 urb->iso_frame_desc[i].length); in dwc2_dump_urb_info()
4620 struct usb_host_endpoint *ep = urb->ep; in _dwc2_hcd_urb_enqueue()
4634 gr = &hsotg->gr_backup; in _dwc2_hcd_urb_enqueue()
4637 dev_vdbg(hsotg->dev, "DWC OTG HCD URB Enqueue\n"); in _dwc2_hcd_urb_enqueue()
4641 if (hsotg->hibernated) { in _dwc2_hcd_urb_enqueue()
4642 if (gr->gotgctl & GOTGCTL_CURMODE_HOST) in _dwc2_hcd_urb_enqueue()
4648 dev_err(hsotg->dev, in _dwc2_hcd_urb_enqueue()
4649 "exit hibernation failed.\n"); in _dwc2_hcd_urb_enqueue()
4652 if (hsotg->in_ppd) { in _dwc2_hcd_urb_enqueue()
4655 dev_err(hsotg->dev, in _dwc2_hcd_urb_enqueue()
4659 if (hsotg->params.power_down == DWC2_POWER_DOWN_PARAM_NONE && in _dwc2_hcd_urb_enqueue()
4660 hsotg->bus_suspended && !hsotg->params.no_clock_gating) { in _dwc2_hcd_urb_enqueue()
4668 return -EINVAL; in _dwc2_hcd_urb_enqueue()
4670 if (usb_pipetype(urb->pipe) == PIPE_ISOCHRONOUS || in _dwc2_hcd_urb_enqueue()
4671 usb_pipetype(urb->pipe) == PIPE_INTERRUPT) { in _dwc2_hcd_urb_enqueue()
4672 spin_lock_irqsave(&hsotg->lock, flags); in _dwc2_hcd_urb_enqueue()
4675 spin_unlock_irqrestore(&hsotg->lock, flags); in _dwc2_hcd_urb_enqueue()
4678 switch (usb_pipetype(urb->pipe)) { in _dwc2_hcd_urb_enqueue()
4693 dwc2_urb = dwc2_hcd_urb_alloc(hsotg, urb->number_of_packets, in _dwc2_hcd_urb_enqueue()
4696 return -ENOMEM; in _dwc2_hcd_urb_enqueue()
4698 dwc2_hcd_urb_set_pipeinfo(hsotg, dwc2_urb, usb_pipedevice(urb->pipe), in _dwc2_hcd_urb_enqueue()
4699 usb_pipeendpoint(urb->pipe), ep_type, in _dwc2_hcd_urb_enqueue()
4700 usb_pipein(urb->pipe), in _dwc2_hcd_urb_enqueue()
4701 usb_endpoint_maxp(&ep->desc), in _dwc2_hcd_urb_enqueue()
4702 usb_endpoint_maxp_mult(&ep->desc)); in _dwc2_hcd_urb_enqueue()
4704 buf = urb->transfer_buffer; in _dwc2_hcd_urb_enqueue()
4707 if (!buf && (urb->transfer_dma & 3)) { in _dwc2_hcd_urb_enqueue()
4708 dev_err(hsotg->dev, in _dwc2_hcd_urb_enqueue()
4711 retval = -EINVAL; in _dwc2_hcd_urb_enqueue()
4716 if (!(urb->transfer_flags & URB_NO_INTERRUPT)) in _dwc2_hcd_urb_enqueue()
4718 if (urb->transfer_flags & URB_ZERO_PACKET) in _dwc2_hcd_urb_enqueue()
4721 dwc2_urb->priv = urb; in _dwc2_hcd_urb_enqueue()
4722 dwc2_urb->buf = buf; in _dwc2_hcd_urb_enqueue()
4723 dwc2_urb->dma = urb->transfer_dma; in _dwc2_hcd_urb_enqueue()
4724 dwc2_urb->length = urb->transfer_buffer_length; in _dwc2_hcd_urb_enqueue()
4725 dwc2_urb->setup_packet = urb->setup_packet; in _dwc2_hcd_urb_enqueue()
4726 dwc2_urb->setup_dma = urb->setup_dma; in _dwc2_hcd_urb_enqueue()
4727 dwc2_urb->flags = tflags; in _dwc2_hcd_urb_enqueue()
4728 dwc2_urb->interval = urb->interval; in _dwc2_hcd_urb_enqueue()
4729 dwc2_urb->status = -EINPROGRESS; in _dwc2_hcd_urb_enqueue()
4731 for (i = 0; i < urb->number_of_packets; ++i) in _dwc2_hcd_urb_enqueue()
4733 urb->iso_frame_desc[i].offset, in _dwc2_hcd_urb_enqueue()
4734 urb->iso_frame_desc[i].length); in _dwc2_hcd_urb_enqueue()
4736 urb->hcpriv = dwc2_urb; in _dwc2_hcd_urb_enqueue()
4737 qh = (struct dwc2_qh *)ep->hcpriv; in _dwc2_hcd_urb_enqueue()
4742 retval = -ENOMEM; in _dwc2_hcd_urb_enqueue()
4745 ep->hcpriv = qh; in _dwc2_hcd_urb_enqueue()
4751 retval = -ENOMEM; in _dwc2_hcd_urb_enqueue()
4755 spin_lock_irqsave(&hsotg->lock, flags); in _dwc2_hcd_urb_enqueue()
4770 spin_unlock_irqrestore(&hsotg->lock, flags); in _dwc2_hcd_urb_enqueue()
4775 dwc2_urb->priv = NULL; in _dwc2_hcd_urb_enqueue()
4777 if (qh_allocated && qh->channel && qh->channel->qh == qh) in _dwc2_hcd_urb_enqueue()
4778 qh->channel->qh = NULL; in _dwc2_hcd_urb_enqueue()
4780 urb->hcpriv = NULL; in _dwc2_hcd_urb_enqueue()
4781 spin_unlock_irqrestore(&hsotg->lock, flags); in _dwc2_hcd_urb_enqueue()
4787 ep->hcpriv = NULL; in _dwc2_hcd_urb_enqueue()
4790 list_for_each_entry_safe(qtd2, qtd2_tmp, &qh->qtd_list, in _dwc2_hcd_urb_enqueue()
4811 dev_dbg(hsotg->dev, "DWC OTG HCD URB Dequeue\n"); in _dwc2_hcd_urb_dequeue()
4814 spin_lock_irqsave(&hsotg->lock, flags); in _dwc2_hcd_urb_dequeue()
4820 if (!urb->hcpriv) { in _dwc2_hcd_urb_dequeue()
4821 dev_dbg(hsotg->dev, "## urb->hcpriv is NULL ##\n"); in _dwc2_hcd_urb_dequeue()
4825 rc = dwc2_hcd_urb_dequeue(hsotg, urb->hcpriv); in _dwc2_hcd_urb_dequeue()
4829 kfree(urb->hcpriv); in _dwc2_hcd_urb_dequeue()
4830 urb->hcpriv = NULL; in _dwc2_hcd_urb_dequeue()
4833 spin_unlock(&hsotg->lock); in _dwc2_hcd_urb_dequeue()
4835 spin_lock(&hsotg->lock); in _dwc2_hcd_urb_dequeue()
4837 dev_dbg(hsotg->dev, "Called usb_hcd_giveback_urb()\n"); in _dwc2_hcd_urb_dequeue()
4838 dev_dbg(hsotg->dev, " urb->status = %d\n", urb->status); in _dwc2_hcd_urb_dequeue()
4840 spin_unlock_irqrestore(&hsotg->lock, flags); in _dwc2_hcd_urb_dequeue()
4855 dev_dbg(hsotg->dev, in _dwc2_hcd_endpoint_disable()
4856 "DWC OTG HCD EP DISABLE: bEndpointAddress=0x%02x, ep->hcpriv=%p\n", in _dwc2_hcd_endpoint_disable()
4857 ep->desc.bEndpointAddress, ep->hcpriv); in _dwc2_hcd_endpoint_disable()
4872 dev_dbg(hsotg->dev, in _dwc2_hcd_endpoint_reset()
4874 ep->desc.bEndpointAddress); in _dwc2_hcd_endpoint_reset()
4876 spin_lock_irqsave(&hsotg->lock, flags); in _dwc2_hcd_endpoint_reset()
4878 spin_unlock_irqrestore(&hsotg->lock, flags); in _dwc2_hcd_endpoint_reset()
4882 * Handles host mode interrupts for the DWC_otg controller. Returns IRQ_NONE if
4909 /* Handles hub class-specific requests */
4926 qh = ep->hcpriv; in _dwc2_hcd_clear_tt_buffer_complete()
4930 spin_lock_irqsave(&hsotg->lock, flags); in _dwc2_hcd_clear_tt_buffer_complete()
4931 qh->tt_buffer_dirty = 0; in _dwc2_hcd_clear_tt_buffer_complete()
4933 if (hsotg->flags.b.port_connect_status) in _dwc2_hcd_clear_tt_buffer_complete()
4936 spin_unlock_irqrestore(&hsotg->lock, flags); in _dwc2_hcd_clear_tt_buffer_complete()
4947 if (hsotg->params.speed == speed) in dwc2_change_bus_speed()
4950 hsotg->params.speed = speed; in dwc2_change_bus_speed()
4951 queue_work(hsotg->wq_otg, &hsotg->wf_otg); in dwc2_change_bus_speed()
4958 if (!hsotg->params.change_speed_quirk) in dwc2_free_dev()
4962 * On removal, set speed to default high-speed. in dwc2_free_dev()
4964 if (udev->parent && udev->parent->speed > USB_SPEED_UNKNOWN && in dwc2_free_dev()
4965 udev->parent->speed < USB_SPEED_HIGH) { in dwc2_free_dev()
4966 dev_info(hsotg->dev, "Set speed to default high-speed\n"); in dwc2_free_dev()
4975 if (!hsotg->params.change_speed_quirk) in dwc2_reset_device()
4978 if (udev->speed == USB_SPEED_HIGH) { in dwc2_reset_device()
4979 dev_info(hsotg->dev, "Set speed to high-speed\n"); in dwc2_reset_device()
4981 } else if ((udev->speed == USB_SPEED_FULL || in dwc2_reset_device()
4982 udev->speed == USB_SPEED_LOW)) { in dwc2_reset_device()
4984 * Change speed setting to full-speed if there's in dwc2_reset_device()
4985 * a full-speed or low-speed device plugged in. in dwc2_reset_device()
4987 dev_info(hsotg->dev, "Set speed to full-speed\n"); in dwc2_reset_device()
5031 dev_dbg(hsotg->dev, "DWC OTG HCD FREE\n"); in dwc2_hcd_free()
5034 dwc2_qh_list_free(hsotg, &hsotg->non_periodic_sched_inactive); in dwc2_hcd_free()
5035 dwc2_qh_list_free(hsotg, &hsotg->non_periodic_sched_waiting); in dwc2_hcd_free()
5036 dwc2_qh_list_free(hsotg, &hsotg->non_periodic_sched_active); in dwc2_hcd_free()
5037 dwc2_qh_list_free(hsotg, &hsotg->periodic_sched_inactive); in dwc2_hcd_free()
5038 dwc2_qh_list_free(hsotg, &hsotg->periodic_sched_ready); in dwc2_hcd_free()
5039 dwc2_qh_list_free(hsotg, &hsotg->periodic_sched_assigned); in dwc2_hcd_free()
5040 dwc2_qh_list_free(hsotg, &hsotg->periodic_sched_queued); in dwc2_hcd_free()
5044 struct dwc2_host_chan *chan = hsotg->hc_ptr_array[i]; in dwc2_hcd_free()
5047 dev_dbg(hsotg->dev, "HCD Free channel #%i, chan=%p\n", in dwc2_hcd_free()
5049 hsotg->hc_ptr_array[i] = NULL; in dwc2_hcd_free()
5054 if (hsotg->params.host_dma) { in dwc2_hcd_free()
5055 if (hsotg->status_buf) { in dwc2_hcd_free()
5056 dma_free_coherent(hsotg->dev, DWC2_HCD_STATUS_BUF_SIZE, in dwc2_hcd_free()
5057 hsotg->status_buf, in dwc2_hcd_free()
5058 hsotg->status_buf_dma); in dwc2_hcd_free()
5059 hsotg->status_buf = NULL; in dwc2_hcd_free()
5062 kfree(hsotg->status_buf); in dwc2_hcd_free()
5063 hsotg->status_buf = NULL; in dwc2_hcd_free()
5068 /* Disable all interrupts */ in dwc2_hcd_free()
5073 if (hsotg->hw_params.snpsid >= DWC2_CORE_REV_3_00a) { in dwc2_hcd_free()
5079 if (hsotg->wq_otg) { in dwc2_hcd_free()
5080 if (!cancel_work_sync(&hsotg->wf_otg)) in dwc2_hcd_free()
5081 flush_workqueue(hsotg->wq_otg); in dwc2_hcd_free()
5082 destroy_workqueue(hsotg->wq_otg); in dwc2_hcd_free()
5085 cancel_work_sync(&hsotg->phy_reset_work); in dwc2_hcd_free()
5087 del_timer(&hsotg->wkp_timer); in dwc2_hcd_free()
5092 /* Turn off all host-specific interrupts */ in dwc2_hcd_release()
5101 * USB bus with the core and calls the hc_driver->start() function. It returns
5106 struct platform_device *pdev = to_platform_device(hsotg->dev); in dwc2_hcd_init()
5115 return -ENODEV; in dwc2_hcd_init()
5117 dev_dbg(hsotg->dev, "DWC OTG HCD INIT\n"); in dwc2_hcd_init()
5119 retval = -ENOMEM; in dwc2_hcd_init()
5122 dev_dbg(hsotg->dev, "hcfg=%08x\n", hcfg); in dwc2_hcd_init()
5125 hsotg->frame_num_array = kcalloc(FRAME_NUM_ARRAY_SIZE, in dwc2_hcd_init()
5126 sizeof(*hsotg->frame_num_array), in dwc2_hcd_init()
5128 if (!hsotg->frame_num_array) in dwc2_hcd_init()
5130 hsotg->last_frame_num_array = in dwc2_hcd_init()
5132 sizeof(*hsotg->last_frame_num_array), GFP_KERNEL); in dwc2_hcd_init()
5133 if (!hsotg->last_frame_num_array) in dwc2_hcd_init()
5136 hsotg->last_frame_num = HFNUM_MAX_FRNUM; in dwc2_hcd_init()
5139 if (hsotg->params.host_dma && in dwc2_hcd_init()
5140 !hsotg->dev->dma_mask) { in dwc2_hcd_init()
5141 dev_warn(hsotg->dev, in dwc2_hcd_init()
5143 hsotg->params.host_dma = false; in dwc2_hcd_init()
5144 hsotg->params.dma_desc_enable = false; in dwc2_hcd_init()
5148 if (hsotg->params.host_dma) { in dwc2_hcd_init()
5149 if (dma_set_mask(hsotg->dev, DMA_BIT_MASK(32)) < 0) in dwc2_hcd_init()
5150 dev_warn(hsotg->dev, "can't set DMA mask\n"); in dwc2_hcd_init()
5151 if (dma_set_coherent_mask(hsotg->dev, DMA_BIT_MASK(32)) < 0) in dwc2_hcd_init()
5152 dev_warn(hsotg->dev, "can't set coherent DMA mask\n"); in dwc2_hcd_init()
5155 if (hsotg->params.change_speed_quirk) { in dwc2_hcd_init()
5160 if (hsotg->params.host_dma) in dwc2_hcd_init()
5163 hcd = usb_create_hcd(&dwc2_hc_driver, hsotg->dev, dev_name(hsotg->dev)); in dwc2_hcd_init()
5167 hcd->has_tt = 1; in dwc2_hcd_init()
5171 retval = -EINVAL; in dwc2_hcd_init()
5174 hcd->rsrc_start = res->start; in dwc2_hcd_init()
5175 hcd->rsrc_len = resource_size(res); in dwc2_hcd_init()
5177 ((struct wrapper_priv_data *)&hcd->hcd_priv)->hsotg = hsotg; in dwc2_hcd_init()
5178 hsotg->priv = hcd; in dwc2_hcd_init()
5181 * Disable the global interrupt until all the interrupt handlers are in dwc2_hcd_init()
5192 retval = -ENOMEM; in dwc2_hcd_init()
5193 hsotg->wq_otg = alloc_ordered_workqueue("dwc2", 0); in dwc2_hcd_init()
5194 if (!hsotg->wq_otg) { in dwc2_hcd_init()
5195 dev_err(hsotg->dev, "Failed to create workqueue\n"); in dwc2_hcd_init()
5198 INIT_WORK(&hsotg->wf_otg, dwc2_conn_id_status_change); in dwc2_hcd_init()
5200 timer_setup(&hsotg->wkp_timer, dwc2_wakeup_detected, 0); in dwc2_hcd_init()
5202 /* Initialize the non-periodic schedule */ in dwc2_hcd_init()
5203 INIT_LIST_HEAD(&hsotg->non_periodic_sched_inactive); in dwc2_hcd_init()
5204 INIT_LIST_HEAD(&hsotg->non_periodic_sched_waiting); in dwc2_hcd_init()
5205 INIT_LIST_HEAD(&hsotg->non_periodic_sched_active); in dwc2_hcd_init()
5208 INIT_LIST_HEAD(&hsotg->periodic_sched_inactive); in dwc2_hcd_init()
5209 INIT_LIST_HEAD(&hsotg->periodic_sched_ready); in dwc2_hcd_init()
5210 INIT_LIST_HEAD(&hsotg->periodic_sched_assigned); in dwc2_hcd_init()
5211 INIT_LIST_HEAD(&hsotg->periodic_sched_queued); in dwc2_hcd_init()
5213 INIT_LIST_HEAD(&hsotg->split_order); in dwc2_hcd_init()
5219 INIT_LIST_HEAD(&hsotg->free_hc_list); in dwc2_hcd_init()
5220 num_channels = hsotg->params.host_channels; in dwc2_hcd_init()
5221 memset(&hsotg->hc_ptr_array[0], 0, sizeof(hsotg->hc_ptr_array)); in dwc2_hcd_init()
5227 channel->hc_num = i; in dwc2_hcd_init()
5228 INIT_LIST_HEAD(&channel->split_order_list_entry); in dwc2_hcd_init()
5229 hsotg->hc_ptr_array[i] = channel; in dwc2_hcd_init()
5233 INIT_DELAYED_WORK(&hsotg->start_work, dwc2_hcd_start_func); in dwc2_hcd_init()
5234 INIT_DELAYED_WORK(&hsotg->reset_work, dwc2_hcd_reset_func); in dwc2_hcd_init()
5235 INIT_WORK(&hsotg->phy_reset_work, dwc2_hcd_phy_reset_func); in dwc2_hcd_init()
5243 if (hsotg->params.host_dma) in dwc2_hcd_init()
5244 hsotg->status_buf = dma_alloc_coherent(hsotg->dev, in dwc2_hcd_init()
5246 &hsotg->status_buf_dma, GFP_KERNEL); in dwc2_hcd_init()
5248 hsotg->status_buf = kzalloc(DWC2_HCD_STATUS_BUF_SIZE, in dwc2_hcd_init()
5251 if (!hsotg->status_buf) in dwc2_hcd_init()
5256 * DMA mode. in dwc2_hcd_init()
5259 if (hsotg->params.dma_desc_enable || in dwc2_hcd_init()
5260 hsotg->params.dma_desc_fs_enable) { in dwc2_hcd_init()
5261 hsotg->desc_gen_cache = kmem_cache_create("dwc2-gen-desc", in dwc2_hcd_init()
5265 if (!hsotg->desc_gen_cache) { in dwc2_hcd_init()
5266 dev_err(hsotg->dev, in dwc2_hcd_init()
5270 * Disable descriptor dma mode since it will not be in dwc2_hcd_init()
5273 hsotg->params.dma_desc_enable = false; in dwc2_hcd_init()
5274 hsotg->params.dma_desc_fs_enable = false; in dwc2_hcd_init()
5277 hsotg->desc_hsisoc_cache = kmem_cache_create("dwc2-hsisoc-desc", in dwc2_hcd_init()
5280 if (!hsotg->desc_hsisoc_cache) { in dwc2_hcd_init()
5281 dev_err(hsotg->dev, in dwc2_hcd_init()
5284 kmem_cache_destroy(hsotg->desc_gen_cache); in dwc2_hcd_init()
5287 * Disable descriptor dma mode since it will not be in dwc2_hcd_init()
5290 hsotg->params.dma_desc_enable = false; in dwc2_hcd_init()
5291 hsotg->params.dma_desc_fs_enable = false; in dwc2_hcd_init()
5295 if (hsotg->params.host_dma) { in dwc2_hcd_init()
5297 * Create kmem caches to handle non-aligned buffer in dwc2_hcd_init()
5298 * in Buffer DMA mode. in dwc2_hcd_init()
5300 hsotg->unaligned_cache = kmem_cache_create("dwc2-unaligned-dma", in dwc2_hcd_init()
5303 if (!hsotg->unaligned_cache) in dwc2_hcd_init()
5304 dev_err(hsotg->dev, in dwc2_hcd_init()
5308 hsotg->otg_port = 1; in dwc2_hcd_init()
5309 hsotg->frame_list = NULL; in dwc2_hcd_init()
5310 hsotg->frame_list_dma = 0; in dwc2_hcd_init()
5311 hsotg->periodic_qh_count = 0; in dwc2_hcd_init()
5314 hsotg->lx_state = DWC2_L3; in dwc2_hcd_init()
5316 hcd->self.otg_port = hsotg->otg_port; in dwc2_hcd_init()
5319 hcd->self.sg_tablesize = 0; in dwc2_hcd_init()
5321 hcd->tpl_support = of_usb_host_tpl_support(hsotg->dev->of_node); in dwc2_hcd_init()
5323 if (!IS_ERR_OR_NULL(hsotg->uphy)) in dwc2_hcd_init()
5324 otg_set_host(hsotg->uphy->otg, &hcd->self); in dwc2_hcd_init()
5331 retval = usb_add_hcd(hcd, hsotg->irq, IRQF_SHARED); in dwc2_hcd_init()
5335 device_wakeup_enable(hcd->self.controller); in dwc2_hcd_init()
5344 kmem_cache_destroy(hsotg->unaligned_cache); in dwc2_hcd_init()
5345 kmem_cache_destroy(hsotg->desc_hsisoc_cache); in dwc2_hcd_init()
5346 kmem_cache_destroy(hsotg->desc_gen_cache); in dwc2_hcd_init()
5354 kfree(hsotg->last_frame_num_array); in dwc2_hcd_init()
5355 kfree(hsotg->frame_num_array); in dwc2_hcd_init()
5358 dev_err(hsotg->dev, "%s() FAILED, returning %d\n", __func__, retval); in dwc2_hcd_init()
5370 dev_dbg(hsotg->dev, "DWC OTG HCD REMOVE\n"); in dwc2_hcd_remove()
5373 dev_dbg(hsotg->dev, "hsotg->hcd = %p\n", hcd); in dwc2_hcd_remove()
5376 dev_dbg(hsotg->dev, "%s: dwc2_hsotg_to_hcd(hsotg) NULL!\n", in dwc2_hcd_remove()
5381 if (!IS_ERR_OR_NULL(hsotg->uphy)) in dwc2_hcd_remove()
5382 otg_set_host(hsotg->uphy->otg, NULL); in dwc2_hcd_remove()
5385 hsotg->priv = NULL; in dwc2_hcd_remove()
5387 kmem_cache_destroy(hsotg->unaligned_cache); in dwc2_hcd_remove()
5388 kmem_cache_destroy(hsotg->desc_hsisoc_cache); in dwc2_hcd_remove()
5389 kmem_cache_destroy(hsotg->desc_gen_cache); in dwc2_hcd_remove()
5395 kfree(hsotg->last_frame_num_array); in dwc2_hcd_remove()
5396 kfree(hsotg->frame_num_array); in dwc2_hcd_remove()
5401 * dwc2_backup_host_registers() - Backup controller host registers.
5412 dev_dbg(hsotg->dev, "%s\n", __func__); in dwc2_backup_host_registers()
5415 hr = &hsotg->hr_backup; in dwc2_backup_host_registers()
5416 hr->hcfg = dwc2_readl(hsotg, HCFG); in dwc2_backup_host_registers()
5417 hr->hflbaddr = dwc2_readl(hsotg, HFLBADDR); in dwc2_backup_host_registers()
5418 hr->haintmsk = dwc2_readl(hsotg, HAINTMSK); in dwc2_backup_host_registers()
5419 for (i = 0; i < hsotg->params.host_channels; ++i) { in dwc2_backup_host_registers()
5420 hr->hcchar[i] = dwc2_readl(hsotg, HCCHAR(i)); in dwc2_backup_host_registers()
5421 hr->hcsplt[i] = dwc2_readl(hsotg, HCSPLT(i)); in dwc2_backup_host_registers()
5422 hr->hcintmsk[i] = dwc2_readl(hsotg, HCINTMSK(i)); in dwc2_backup_host_registers()
5423 hr->hctsiz[i] = dwc2_readl(hsotg, HCTSIZ(i)); in dwc2_backup_host_registers()
5424 hr->hcidma[i] = dwc2_readl(hsotg, HCDMA(i)); in dwc2_backup_host_registers()
5425 hr->hcidmab[i] = dwc2_readl(hsotg, HCDMAB(i)); in dwc2_backup_host_registers()
5428 hr->hprt0 = dwc2_read_hprt0(hsotg); in dwc2_backup_host_registers()
5429 hr->hfir = dwc2_readl(hsotg, HFIR); in dwc2_backup_host_registers()
5430 hr->hptxfsiz = dwc2_readl(hsotg, HPTXFSIZ); in dwc2_backup_host_registers()
5431 hr->valid = true; in dwc2_backup_host_registers()
5437 * dwc2_restore_host_registers() - Restore controller host registers.
5448 dev_dbg(hsotg->dev, "%s\n", __func__); in dwc2_restore_host_registers()
5451 hr = &hsotg->hr_backup; in dwc2_restore_host_registers()
5452 if (!hr->valid) { in dwc2_restore_host_registers()
5453 dev_err(hsotg->dev, "%s: no host registers to restore\n", in dwc2_restore_host_registers()
5455 return -EINVAL; in dwc2_restore_host_registers()
5457 hr->valid = false; in dwc2_restore_host_registers()
5459 dwc2_writel(hsotg, hr->hcfg, HCFG); in dwc2_restore_host_registers()
5460 dwc2_writel(hsotg, hr->hflbaddr, HFLBADDR); in dwc2_restore_host_registers()
5461 dwc2_writel(hsotg, hr->haintmsk, HAINTMSK); in dwc2_restore_host_registers()
5463 for (i = 0; i < hsotg->params.host_channels; ++i) { in dwc2_restore_host_registers()
5464 dwc2_writel(hsotg, hr->hcchar[i], HCCHAR(i)); in dwc2_restore_host_registers()
5465 dwc2_writel(hsotg, hr->hcsplt[i], HCSPLT(i)); in dwc2_restore_host_registers()
5466 dwc2_writel(hsotg, hr->hcintmsk[i], HCINTMSK(i)); in dwc2_restore_host_registers()
5467 dwc2_writel(hsotg, hr->hctsiz[i], HCTSIZ(i)); in dwc2_restore_host_registers()
5468 dwc2_writel(hsotg, hr->hcidma[i], HCDMA(i)); in dwc2_restore_host_registers()
5469 dwc2_writel(hsotg, hr->hcidmab[i], HCDMAB(i)); in dwc2_restore_host_registers()
5472 dwc2_writel(hsotg, hr->hprt0, HPRT0); in dwc2_restore_host_registers()
5473 dwc2_writel(hsotg, hr->hfir, HFIR); in dwc2_restore_host_registers()
5474 dwc2_writel(hsotg, hr->hptxfsiz, HPTXFSIZ); in dwc2_restore_host_registers()
5475 hsotg->frame_number = 0; in dwc2_restore_host_registers()
5481 * dwc2_host_enter_hibernation() - Put controller in Hibernation.
5494 dev_dbg(hsotg->dev, "Preparing host for hibernation\n"); in dwc2_host_enter_hibernation()
5497 dev_err(hsotg->dev, "%s: failed to backup global registers\n", in dwc2_host_enter_hibernation()
5503 dev_err(hsotg->dev, "%s: failed to backup host registers\n", in dwc2_host_enter_hibernation()
5508 /* Enter USB Suspend Mode */ in dwc2_host_enter_hibernation()
5516 dev_warn(hsotg->dev, "Suspend wasn't generated\n"); in dwc2_host_enter_hibernation()
5519 * We need to disable interrupts to prevent servicing of any IRQ in dwc2_host_enter_hibernation()
5520 * during going to hibernation in dwc2_host_enter_hibernation()
5522 spin_lock_irqsave(&hsotg->lock, flags); in dwc2_host_enter_hibernation()
5523 hsotg->lx_state = DWC2_L2; in dwc2_host_enter_hibernation()
5562 /* Unmask host mode interrupts in GPWRDN */ in dwc2_host_enter_hibernation()
5581 hsotg->hibernated = 1; in dwc2_host_enter_hibernation()
5582 hsotg->bus_suspended = 1; in dwc2_host_enter_hibernation()
5583 dev_dbg(hsotg->dev, "Host hibernation completed\n"); in dwc2_host_enter_hibernation()
5584 spin_unlock_irqrestore(&hsotg->lock, flags); in dwc2_host_enter_hibernation()
5595 * Return: non-zero if failed to enter to hibernation.
5597 * This function is for exiting from Host mode hibernation by
5598 * Host Initiated Resume/Reset and Device Initiated Remote-Wakeup.
5609 gr = &hsotg->gr_backup; in dwc2_host_exit_hibernation()
5610 hr = &hsotg->hr_backup; in dwc2_host_exit_hibernation()
5612 dev_dbg(hsotg->dev, in dwc2_host_exit_hibernation()
5617 hsotg->hibernated = 0; in dwc2_host_exit_hibernation()
5622 * core is in Device mode(gintsts.curmode == 0) in dwc2_host_exit_hibernation()
5629 /* De-assert Restore */ in dwc2_host_exit_hibernation()
5636 dwc2_writel(hsotg, gr->gusbcfg, GUSBCFG); in dwc2_host_exit_hibernation()
5637 dwc2_writel(hsotg, hr->hcfg, HCFG); in dwc2_host_exit_hibernation()
5644 /* De-assert Wakeup Logic */ in dwc2_host_exit_hibernation()
5645 if (!(rem_wakeup && hsotg->hw_params.snpsid >= DWC2_CORE_REV_4_30a)) { in dwc2_host_exit_hibernation()
5652 hprt0 = hr->hprt0; in dwc2_host_exit_hibernation()
5658 hprt0 = hr->hprt0; in dwc2_host_exit_hibernation()
5675 /* De-assert Wakeup Logic */ in dwc2_host_exit_hibernation()
5676 if ((rem_wakeup && hsotg->hw_params.snpsid >= DWC2_CORE_REV_4_30a)) { in dwc2_host_exit_hibernation()
5702 dev_err(hsotg->dev, "%s: failed to restore registers\n", in dwc2_host_exit_hibernation()
5710 dev_err(hsotg->dev, "%s: failed to restore host registers\n", in dwc2_host_exit_hibernation()
5718 * Change "port_connect_status_change" flag to re-enumerate, in dwc2_host_exit_hibernation()
5719 * because after exit from hibernation port connection status in dwc2_host_exit_hibernation()
5722 hsotg->flags.b.port_connect_status_change = 1; in dwc2_host_exit_hibernation()
5725 hsotg->hibernated = 0; in dwc2_host_exit_hibernation()
5726 hsotg->bus_suspended = 0; in dwc2_host_exit_hibernation()
5727 hsotg->lx_state = DWC2_L0; in dwc2_host_exit_hibernation()
5728 dev_dbg(hsotg->dev, "Host hibernation restore complete\n"); in dwc2_host_exit_hibernation()
5734 struct usb_device *root_hub = dwc2_hsotg_to_hcd(dwc2)->self.root_hub; in dwc2_host_can_poweroff_phy()
5737 if (!device_may_wakeup(dwc2->dev)) in dwc2_host_can_poweroff_phy()
5752 * dwc2_host_enter_partial_power_down() - Put controller in partial
5757 * Return: non-zero if failed to enter host partial power down.
5759 * This function is for entering Host mode partial power down.
5767 dev_dbg(hsotg->dev, "Entering host partial power down started.\n"); in dwc2_host_enter_partial_power_down()
5769 /* Put this port in suspend mode. */ in dwc2_host_enter_partial_power_down()
5777 dev_warn(hsotg->dev, "Suspend wasn't generated\n"); in dwc2_host_enter_partial_power_down()
5782 dev_err(hsotg->dev, "%s: failed to backup global registers\n", in dwc2_host_enter_partial_power_down()
5789 dev_err(hsotg->dev, "%s: failed to backup host registers\n", in dwc2_host_enter_partial_power_down()
5815 hsotg->in_ppd = 1; in dwc2_host_enter_partial_power_down()
5816 hsotg->lx_state = DWC2_L2; in dwc2_host_enter_partial_power_down()
5817 hsotg->bus_suspended = true; in dwc2_host_enter_partial_power_down()
5819 dev_dbg(hsotg->dev, "Entering host partial power down completed.\n"); in dwc2_host_enter_partial_power_down()
5825 * dwc2_host_exit_partial_power_down() - Exit controller from host partial
5832 * Return: non-zero if failed to exit host partial power down.
5834 * This function is for exiting from Host mode partial power down.
5843 dev_dbg(hsotg->dev, "Exiting host partial power down started.\n"); in dwc2_host_exit_partial_power_down()
5863 dev_err(hsotg->dev, "%s: failed to restore registers\n", in dwc2_host_exit_partial_power_down()
5870 dev_err(hsotg->dev, "%s: failed to restore host registers\n", in dwc2_host_exit_partial_power_down()
5876 /* Drive resume signaling and exit suspend mode on the port. */ in dwc2_host_exit_partial_power_down()
5889 hsotg->bus_suspended = false; in dwc2_host_exit_partial_power_down()
5899 mod_timer(&hsotg->wkp_timer, in dwc2_host_exit_partial_power_down()
5904 hsotg->in_ppd = 0; in dwc2_host_exit_partial_power_down()
5905 hsotg->lx_state = DWC2_L0; in dwc2_host_exit_partial_power_down()
5907 dev_dbg(hsotg->dev, "Exiting host partial power down completed.\n"); in dwc2_host_exit_partial_power_down()
5912 * dwc2_host_enter_clock_gating() - Put controller in clock gating.
5916 * This function is for entering Host mode clock gating.
5923 dev_dbg(hsotg->dev, "Entering host clock gating.\n"); in dwc2_host_enter_clock_gating()
5925 /* Put this port in suspend mode. */ in dwc2_host_enter_clock_gating()
5942 hsotg->bus_suspended = true; in dwc2_host_enter_clock_gating()
5943 hsotg->lx_state = DWC2_L2; in dwc2_host_enter_clock_gating()
5947 * dwc2_host_exit_clock_gating() - Exit controller from clock gating.
5952 * This function is for exiting Host mode clock gating.
5959 dev_dbg(hsotg->dev, "Exiting host clock gating.\n"); in dwc2_host_exit_clock_gating()
5973 /* Drive resume signaling and exit suspend mode on the port. */ in dwc2_host_exit_clock_gating()
5989 hsotg->bus_suspended = false; in dwc2_host_exit_clock_gating()
5990 hsotg->lx_state = DWC2_L0; in dwc2_host_exit_clock_gating()
5992 mod_timer(&hsotg->wkp_timer, in dwc2_host_exit_clock_gating()