Re: [PATCH 1/2] staging: r8188eu: Use usb_control_msg_recv/send() in usbctrl_vendorreq()

From: Pavel Skripkin
Date: Tue Aug 24 2021 - 08:09:22 EST


On 8/24/21 3:01 PM, Fabio M. De Francesco wrote:
On Tuesday, August 24, 2021 1:07:46 PM CEST Pavel Skripkin wrote:

Btw, not related to your patch, but I start think, that this check:


if (!pIo_buf) {
DBG_88E("[%s] pIo_buf == NULL\n", __func__);
status = -ENOMEM;
goto release_mutex;
}

Should be wrapped as

if (WARN_ON(unlikely(!pIo_buf)) {
...
}

Since usb_vendor_req_buf is initialized in ->probe() and I can't see possible calltrace, which can cause zeroing this pointer.

I see that usb_vendor_req_buf is initialized in rtw_init_intf_priv(). It depends on a
kzalloc() success on allocating memory. Obviously it could fail to allocate. If it fails,
rtw_init_intf_priv() returns _FAIL to its caller(s) (whichever they are - I didn't go too
deep in understanding the possible calls chains).


Call chain is the most interesting part here :)

rtw_drv_init() <-- probe()
usb_dvobj_init()
rtw_init_intf_priv()

If kzalloc fails, then whole ->probe() routine fails, i.e device will be disconnected. There is no read() calls before rtw_init_intf_priv(), so if kzalloc() call was successful, there is no way how usb_vendor_req_buf can be NULL, since read() can happen only in case of successfully connected device.


Anyway, it can be NULL in case of out-of-bound write or smth else, but there is no explicit usb_alloc_vendor_req_buf = NULL in this driver.
We should complain about completely wrong driver behavior, IMO :)


Does it make sense?



With regards,
Pavel Skripkin