On Fri, Jun 11, 2021 at 06:15:10PM +0800, Jiapeng Chong wrote: > Use ARRAY_SIZE instead of dividing sizeof array with sizeof an > element. > > Clean up the following coccicheck warning: > > ./tools/usb/usbip/src/usbipd.c:536:19-20: WARNING: Use ARRAY_SIZE. Why are you assuming that coccicheck should be run on userspace code? > > Reported-by: Abaci Robot <abaci@xxxxxxxxxxxxxxxxx> > Signed-off-by: Jiapeng Chong <jiapeng.chong@xxxxxxxxxxxxxxxxx> > --- > Changes in v2: > -Add ARRAY_SIZE definition to usbip_common.h file. > > tools/usb/usbip/libsrc/usbip_common.h | 2 ++ > tools/usb/usbip/src/usbipd.c | 3 +-- > 2 files changed, 3 insertions(+), 2 deletions(-) > > diff --git a/tools/usb/usbip/libsrc/usbip_common.h b/tools/usb/usbip/libsrc/usbip_common.h > index 73a367a..4e12dc4 100644 > --- a/tools/usb/usbip/libsrc/usbip_common.h > +++ b/tools/usb/usbip/libsrc/usbip_common.h > @@ -101,6 +101,8 @@ > abort(); \ > } while (0) > > +#define ARRAY_SIZE(arr) (sizeof(arr) / sizeof((arr)[0])) Why is this needed? And if it really really is, why not define it in a way that ALL tools can use it. And then fix it up be correct for cases when you might call this when it is not an array. This is a very naive implementation. > + > struct usbip_usb_interface { > uint8_t bInterfaceClass; > uint8_t bInterfaceSubClass; > diff --git a/tools/usb/usbip/src/usbipd.c b/tools/usb/usbip/src/usbipd.c > index 48398a7..4826d13 100644 > --- a/tools/usb/usbip/src/usbipd.c > +++ b/tools/usb/usbip/src/usbipd.c > @@ -532,8 +532,7 @@ static int do_standalone_mode(int daemonize, int ipv4, int ipv6) > usbip_driver_close(driver); > return -1; > } > - nsockfd = listen_all_addrinfo(ai_head, sockfdlist, > - sizeof(sockfdlist) / sizeof(*sockfdlist)); > + nsockfd = listen_all_addrinfo(ai_head, sockfdlist, ARRAY_SIZE(sockfdlist)); The code here is correct, right? So this is not necessary unless you do this for all in-tree userspace tools at the same time. thanks, greg k-h