Message ID | 20200625124428.83564-1-colin.king@canonical.com (mailing list archive) |
---|---|
State | Mainlined |
Commit | 38b1927e5bf9bcad4a2e33189ef1c5569f9599ba |
Headers | show |
Series | phy: sun4i-usb: fix dereference of pointer phy0 before it is null checked | expand |
On 25-06-20, 13:44, Colin King wrote: > From: Colin Ian King <colin.king@canonical.com> > > Currently pointer phy0 is being dereferenced via the assignment of > phy on the call to phy_get_drvdata before phy0 is null checked, this > can lead to a null pointer dereference. Fix this by performing the > null check on phy0 before the call to phy_get_drvdata. Also replace > the phy0 == NULL check with the more usual !phy0 idiom. Applied, thanks
diff --git a/drivers/phy/allwinner/phy-sun4i-usb.c b/drivers/phy/allwinner/phy-sun4i-usb.c index 7e09ad6a0b42..f7a59a75df1a 100644 --- a/drivers/phy/allwinner/phy-sun4i-usb.c +++ b/drivers/phy/allwinner/phy-sun4i-usb.c @@ -545,13 +545,14 @@ static void sun4i_usb_phy0_id_vbus_det_scan(struct work_struct *work) struct sun4i_usb_phy_data *data = container_of(work, struct sun4i_usb_phy_data, detect.work); struct phy *phy0 = data->phys[0].phy; - struct sun4i_usb_phy *phy = phy_get_drvdata(phy0); + struct sun4i_usb_phy *phy; bool force_session_end, id_notify = false, vbus_notify = false; int id_det, vbus_det; - if (phy0 == NULL) + if (!phy0) return; + phy = phy_get_drvdata(phy0); id_det = sun4i_usb_phy0_get_id_det(data); vbus_det = sun4i_usb_phy0_get_vbus_det(data);