UPSTREAM: Revert "usb: dwc3: dwc3-qcom: Enable tx-fifo-resize property by default"
This reverts commit cefdd52fa0455c0555c30927386ee466a108b060.
On sc7180-trogdor class devices with 'fw_devlink=permissive' and KASAN
enabled, you'll see a Use-After-Free reported at bootup.
The root of the problem is that dwc3_qcom_of_register_core() is adding
a devm-allocated "tx-fifo-resize" property to its device tree node
using of_add_property().
The issue is that of_add_property() makes a _permanent_ addition to
the device tree that lasts until reboot. That means allocating memory
for the property using "devm" managed memory is a terrible idea since
that memory will be freed upon probe deferral or device unbinding.
Let's revert the patch since the system is still functional without
it. The fact that of_add_property() makes a permanent change is extra
fodder for those folks who were aruging that the device tree isn't
really the right way to pass information between parts of the
driver. It is an exercise left to the reader to submit a patch
re-adding the new feature in a way that makes everyone happier.
Fixes: cefdd52fa045 ("usb: dwc3: dwc3-qcom: Enable tx-fifo-resize property by default")
Cc: stable <stable@vger.kernel.org>
Reviewed-by: Stephen Boyd <swboyd@chromium.org>
Signed-off-by: Douglas Anderson <dianders@chromium.org>
Link: https://lore.kernel.org/r/20211207094327.1.Ie3cde3443039342e2963262a4c3ac36dc2c08b30@changeid
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
(cherry picked from commit 6a97cee39d8f2ed4d6e35a09a302dae1d566db36)
Bug: 187129171
Signed-off-by: Connor O'Brien <connoro@google.com>
Change-Id: I69a18d3518e8cc9c43e93225f7427642b42a931b
			
			
This commit is contained in:
		 Douglas Anderson
					Douglas Anderson
				
			
				
					committed by
					
						 Connor O'Brien
						Connor O'Brien
					
				
			
			
				
	
			
			
			 Connor O'Brien
						Connor O'Brien
					
				
			
						parent
						
							e4757e9070
						
					
				
				
					commit
					e4f41530d4
				
			| @@ -644,7 +644,6 @@ static int dwc3_qcom_of_register_core(struct platform_device *pdev) | ||||
| 	struct dwc3_qcom	*qcom = platform_get_drvdata(pdev); | ||||
| 	struct device_node	*np = pdev->dev.of_node, *dwc3_np; | ||||
| 	struct device		*dev = &pdev->dev; | ||||
| 	struct property		*prop; | ||||
| 	int			ret; | ||||
| 
 | ||||
| 	dwc3_np = of_get_child_by_name(np, "dwc3"); | ||||
| @@ -653,20 +652,6 @@ static int dwc3_qcom_of_register_core(struct platform_device *pdev) | ||||
| 		return -ENODEV; | ||||
| 	} | ||||
| 
 | ||||
| 	prop = devm_kzalloc(dev, sizeof(*prop), GFP_KERNEL); | ||||
| 	if (!prop) { | ||||
| 		ret = -ENOMEM; | ||||
| 		dev_err(dev, "unable to allocate memory for property\n"); | ||||
| 		goto node_put; | ||||
| 	} | ||||
| 
 | ||||
| 	prop->name = "tx-fifo-resize"; | ||||
| 	ret = of_add_property(dwc3_np, prop); | ||||
| 	if (ret) { | ||||
| 		dev_err(dev, "unable to add property\n"); | ||||
| 		goto node_put; | ||||
| 	} | ||||
| 
 | ||||
| 	ret = of_platform_populate(np, NULL, NULL, dev); | ||||
| 	if (ret) { | ||||
| 		dev_err(dev, "failed to register dwc3 core - %d\n", ret); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user