Commit 41f5a097 authored by Johan Hovold's avatar Johan Hovold Committed by Greg Kroah-Hartman

USB: dwc3: qcom: fix wakeup after probe deferral

The Qualcomm glue driver is overriding the interrupt trigger types
defined by firmware when requesting the wakeup interrupts during probe.

This can lead to a failure to map the DP/DM wakeup interrupts after a
probe deferral as the firmware defined trigger types do not match the
type used for the initial mapping:

	irq: type mismatch, failed to map hwirq-14 for interrupt-controller@b220000!
	irq: type mismatch, failed to map hwirq-15 for interrupt-controller@b220000!

Fix this by not overriding the firmware provided trigger types when
requesting the wakeup interrupts.

Fixes: a4333c3a ("usb: dwc3: Add Qualcomm DWC3 glue driver")
Cc: stable@vger.kernel.org      # 4.18
Signed-off-by: default avatarJohan Hovold <johan+linaro@kernel.org>
Reviewed-by: default avatarAndrew Halaney <ahalaney@redhat.com>
Link: https://lore.kernel.org/r/20231120161607.7405-3-johan+linaro@kernel.orgSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 0c2671f3
...@@ -549,7 +549,7 @@ static int dwc3_qcom_setup_irq(struct platform_device *pdev) ...@@ -549,7 +549,7 @@ static int dwc3_qcom_setup_irq(struct platform_device *pdev)
irq_set_status_flags(irq, IRQ_NOAUTOEN); irq_set_status_flags(irq, IRQ_NOAUTOEN);
ret = devm_request_threaded_irq(qcom->dev, irq, NULL, ret = devm_request_threaded_irq(qcom->dev, irq, NULL,
qcom_dwc3_resume_irq, qcom_dwc3_resume_irq,
IRQF_TRIGGER_HIGH | IRQF_ONESHOT, IRQF_ONESHOT,
"qcom_dwc3 HS", qcom); "qcom_dwc3 HS", qcom);
if (ret) { if (ret) {
dev_err(qcom->dev, "hs_phy_irq failed: %d\n", ret); dev_err(qcom->dev, "hs_phy_irq failed: %d\n", ret);
...@@ -564,7 +564,7 @@ static int dwc3_qcom_setup_irq(struct platform_device *pdev) ...@@ -564,7 +564,7 @@ static int dwc3_qcom_setup_irq(struct platform_device *pdev)
irq_set_status_flags(irq, IRQ_NOAUTOEN); irq_set_status_flags(irq, IRQ_NOAUTOEN);
ret = devm_request_threaded_irq(qcom->dev, irq, NULL, ret = devm_request_threaded_irq(qcom->dev, irq, NULL,
qcom_dwc3_resume_irq, qcom_dwc3_resume_irq,
IRQF_TRIGGER_HIGH | IRQF_ONESHOT, IRQF_ONESHOT,
"qcom_dwc3 DP_HS", qcom); "qcom_dwc3 DP_HS", qcom);
if (ret) { if (ret) {
dev_err(qcom->dev, "dp_hs_phy_irq failed: %d\n", ret); dev_err(qcom->dev, "dp_hs_phy_irq failed: %d\n", ret);
...@@ -579,7 +579,7 @@ static int dwc3_qcom_setup_irq(struct platform_device *pdev) ...@@ -579,7 +579,7 @@ static int dwc3_qcom_setup_irq(struct platform_device *pdev)
irq_set_status_flags(irq, IRQ_NOAUTOEN); irq_set_status_flags(irq, IRQ_NOAUTOEN);
ret = devm_request_threaded_irq(qcom->dev, irq, NULL, ret = devm_request_threaded_irq(qcom->dev, irq, NULL,
qcom_dwc3_resume_irq, qcom_dwc3_resume_irq,
IRQF_TRIGGER_HIGH | IRQF_ONESHOT, IRQF_ONESHOT,
"qcom_dwc3 DM_HS", qcom); "qcom_dwc3 DM_HS", qcom);
if (ret) { if (ret) {
dev_err(qcom->dev, "dm_hs_phy_irq failed: %d\n", ret); dev_err(qcom->dev, "dm_hs_phy_irq failed: %d\n", ret);
...@@ -594,7 +594,7 @@ static int dwc3_qcom_setup_irq(struct platform_device *pdev) ...@@ -594,7 +594,7 @@ static int dwc3_qcom_setup_irq(struct platform_device *pdev)
irq_set_status_flags(irq, IRQ_NOAUTOEN); irq_set_status_flags(irq, IRQ_NOAUTOEN);
ret = devm_request_threaded_irq(qcom->dev, irq, NULL, ret = devm_request_threaded_irq(qcom->dev, irq, NULL,
qcom_dwc3_resume_irq, qcom_dwc3_resume_irq,
IRQF_TRIGGER_HIGH | IRQF_ONESHOT, IRQF_ONESHOT,
"qcom_dwc3 SS", qcom); "qcom_dwc3 SS", qcom);
if (ret) { if (ret) {
dev_err(qcom->dev, "ss_phy_irq failed: %d\n", ret); dev_err(qcom->dev, "ss_phy_irq failed: %d\n", ret);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment