summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMinda Chen <minda.chen@starfivetech.com>2023-10-12 11:44:34 +0300
committerAndy Hu <andy.hu@starfivetech.com>2023-10-18 13:53:00 +0300
commitde86bf5edc2bde10abbb901240908a55827c5d91 (patch)
treebb9e60be3f4809c52ed5361220d141dc4eb8a2d9
parent6f58ddddafb8069201d9d237c42ee22b02b1365a (diff)
downloadu-boot-de86bf5edc2bde10abbb901240908a55827c5d91.tar.xz
usb: fix TRB_TRANSFER return null pointer issue
xhci_wait_for_event() wait TRB_TRANSFER may return null pointer, shoud checkit avoid crash. Read usb device info maybe failed, should check it and do not register usb device. uboot should rescan usb device and register. Signed-off-by: Minda Chen <minda.chen@starfivetech.com>
-rw-r--r--common/usb.c24
-rw-r--r--drivers/usb/host/xhci-ring.c2
2 files changed, 20 insertions, 6 deletions
diff --git a/common/usb.c b/common/usb.c
index aad13fd9c5..68885d6ee4 100644
--- a/common/usb.c
+++ b/common/usb.c
@@ -1144,20 +1144,32 @@ int usb_select_config(struct usb_device *dev)
memset(dev->mf, 0, sizeof(dev->mf));
memset(dev->prod, 0, sizeof(dev->prod));
memset(dev->serial, 0, sizeof(dev->serial));
- if (dev->descriptor.iManufacturer)
- usb_string(dev, dev->descriptor.iManufacturer,
+ if (dev->descriptor.iManufacturer) {
+ err = usb_string(dev, dev->descriptor.iManufacturer,
dev->mf, sizeof(dev->mf));
- if (dev->descriptor.iProduct)
- usb_string(dev, dev->descriptor.iProduct,
+ if (err < 0)
+ goto decriptor_err;
+ } if (dev->descriptor.iProduct) {
+ err = usb_string(dev, dev->descriptor.iProduct,
dev->prod, sizeof(dev->prod));
- if (dev->descriptor.iSerialNumber)
- usb_string(dev, dev->descriptor.iSerialNumber,
+ if (err < 0)
+ goto decriptor_err;
+ }
+ if (dev->descriptor.iSerialNumber) {
+ err = usb_string(dev, dev->descriptor.iSerialNumber,
dev->serial, sizeof(dev->serial));
+ if (err < 0)
+ goto decriptor_err;
+ }
debug("Manufacturer %s\n", dev->mf);
debug("Product %s\n", dev->prod);
debug("SerialNumber %s\n", dev->serial);
return 0;
+
+decriptor_err:
+ printf("failed to get usb device info %d\n", err);
+ return err;
}
int usb_setup_device(struct usb_device *dev, bool do_read,
diff --git a/drivers/usb/host/xhci-ring.c b/drivers/usb/host/xhci-ring.c
index 35bd5cd29e..0bc44752be 100644
--- a/drivers/usb/host/xhci-ring.c
+++ b/drivers/usb/host/xhci-ring.c
@@ -499,6 +499,8 @@ static void abort_td(struct usb_device *udev, int ep_index)
xhci_queue_command(ctrl, NULL, udev->slot_id, ep_index, TRB_STOP_RING);
event = xhci_wait_for_event(ctrl, TRB_TRANSFER);
+ if (!event)
+ return;
field = le32_to_cpu(event->trans_event.flags);
BUG_ON(TRB_TO_SLOT_ID(field) != udev->slot_id);
BUG_ON(TRB_TO_EP_INDEX(field) != ep_index);