DWC_usb31 periodic transfer at 48K+ bytes per interval may need modification to the TX/RX packet threshold to achieve optimal result. Add properties to make it configurable. By default, periodic ESS TX and RX threshold are not enabled. To enable TX or RX threshold (host mode only), both packet threshold count and max burst size properties must be set to a valid non-zero value 1-16. DWC_usb31 programming guide section 1.2.3 and 1.2.4. Cc: John Youn <johnyoun@synopsys.com> Reviewed-by: Rob Herring <robh@kernel.org> Signed-off-by: Thinh Nguyen <thinhn@synopsys.com> Signed-off-by: Felipe Balbi <felipe.balbi@linux.intel.com>
91 lines
4.4 KiB
Plaintext
91 lines
4.4 KiB
Plaintext
synopsys DWC3 CORE
|
|
|
|
DWC3- USB3 CONTROLLER. Complies to the generic USB binding properties
|
|
as described in 'usb/generic.txt'
|
|
|
|
Required properties:
|
|
- compatible: must be "snps,dwc3"
|
|
- reg : Address and length of the register set for the device
|
|
- interrupts: Interrupts used by the dwc3 controller.
|
|
|
|
Optional properties:
|
|
- usb-phy : array of phandle for the PHY device. The first element
|
|
in the array is expected to be a handle to the USB2/HS PHY and
|
|
the second element is expected to be a handle to the USB3/SS PHY
|
|
- phys: from the *Generic PHY* bindings
|
|
- phy-names: from the *Generic PHY* bindings; supported names are "usb2-phy"
|
|
or "usb3-phy".
|
|
- snps,usb3_lpm_capable: determines if platform is USB3 LPM capable
|
|
- snps,disable_scramble_quirk: true when SW should disable data scrambling.
|
|
Only really useful for FPGA builds.
|
|
- snps,has-lpm-erratum: true when DWC3 was configured with LPM Erratum enabled
|
|
- snps,lpm-nyet-threshold: LPM NYET threshold
|
|
- snps,u2exit_lfps_quirk: set if we want to enable u2exit lfps quirk
|
|
- snps,u2ss_inp3_quirk: set if we enable P3 OK for U2/SS Inactive quirk
|
|
- snps,req_p1p2p3_quirk: when set, the core will always request for
|
|
P1/P2/P3 transition sequence.
|
|
- snps,del_p1p2p3_quirk: when set core will delay P1/P2/P3 until a certain
|
|
amount of 8B10B errors occur.
|
|
- snps,del_phy_power_chg_quirk: when set core will delay PHY power change
|
|
from P0 to P1/P2/P3.
|
|
- snps,lfps_filter_quirk: when set core will filter LFPS reception.
|
|
- snps,rx_detect_poll_quirk: when set core will disable a 400us delay to start
|
|
Polling LFPS after RX.Detect.
|
|
- snps,tx_de_emphasis_quirk: when set core will set Tx de-emphasis value.
|
|
- snps,tx_de_emphasis: the value driven to the PHY is controlled by the
|
|
LTSSM during USB3 Compliance mode.
|
|
- snps,dis_u3_susphy_quirk: when set core will disable USB3 suspend phy.
|
|
- snps,dis_u2_susphy_quirk: when set core will disable USB2 suspend phy.
|
|
- snps,dis_enblslpm_quirk: when set clears the enblslpm in GUSB2PHYCFG,
|
|
disabling the suspend signal to the PHY.
|
|
- snps,dis_rxdet_inp3_quirk: when set core will disable receiver detection
|
|
in PHY P3 power state.
|
|
- snps,dis-u2-freeclk-exists-quirk: when set, clear the u2_freeclk_exists
|
|
in GUSB2PHYCFG, specify that USB2 PHY doesn't provide
|
|
a free-running PHY clock.
|
|
- snps,dis-del-phy-power-chg-quirk: when set core will change PHY power
|
|
from P0 to P1/P2/P3 without delay.
|
|
- snps,dis-tx-ipgap-linecheck-quirk: when set, disable u2mac linestate check
|
|
during HS transmit.
|
|
- snps,dis_metastability_quirk: when set, disable metastability workaround.
|
|
CAUTION: use only if you are absolutely sure of it.
|
|
- snps,is-utmi-l1-suspend: true when DWC3 asserts output signal
|
|
utmi_l1_suspend_n, false when asserts utmi_sleep_n
|
|
- snps,hird-threshold: HIRD threshold
|
|
- snps,hsphy_interface: High-Speed PHY interface selection between "utmi" for
|
|
UTMI+ and "ulpi" for ULPI when the DWC_USB3_HSPHY_INTERFACE has value 3.
|
|
- snps,quirk-frame-length-adjustment: Value for GFLADJ_30MHZ field of GFLADJ
|
|
register for post-silicon frame length adjustment when the
|
|
fladj_30mhz_sdbnd signal is invalid or incorrect.
|
|
- snps,rx-thr-num-pkt-prd: periodic ESS RX packet threshold count - host mode
|
|
only. Set this and rx-max-burst-prd to a valid,
|
|
non-zero value 1-16 (DWC_usb31 programming guide
|
|
section 1.2.4) to enable periodic ESS RX threshold.
|
|
- snps,rx-max-burst-prd: max periodic ESS RX burst size - host mode only. Set
|
|
this and rx-thr-num-pkt-prd to a valid, non-zero value
|
|
1-16 (DWC_usb31 programming guide section 1.2.4) to
|
|
enable periodic ESS RX threshold.
|
|
- snps,tx-thr-num-pkt-prd: periodic ESS TX packet threshold count - host mode
|
|
only. Set this and tx-max-burst-prd to a valid,
|
|
non-zero value 1-16 (DWC_usb31 programming guide
|
|
section 1.2.3) to enable periodic ESS TX threshold.
|
|
- snps,tx-max-burst-prd: max periodic ESS TX burst size - host mode only. Set
|
|
this and tx-thr-num-pkt-prd to a valid, non-zero value
|
|
1-16 (DWC_usb31 programming guide section 1.2.3) to
|
|
enable periodic ESS TX threshold.
|
|
|
|
- <DEPRECATED> tx-fifo-resize: determines if the FIFO *has* to be reallocated.
|
|
|
|
- in addition all properties from usb-xhci.txt from the current directory are
|
|
supported as well
|
|
|
|
|
|
This is usually a subnode to DWC3 glue to which it is connected.
|
|
|
|
dwc3@4a030000 {
|
|
compatible = "snps,dwc3";
|
|
reg = <0x4a030000 0xcfff>;
|
|
interrupts = <0 92 4>
|
|
usb-phy = <&usb2_phy>, <&usb3,phy>;
|
|
};
|