Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp1260929pxb; Wed, 20 Oct 2021 01:16:08 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwj2NNpoFPQWC++8aM/UFHddyMYbKQYsl0W8tTEap2grHpsyXJt9zeDxt6GB7JcqiF9OJO0 X-Received: by 2002:a17:90a:4a85:: with SMTP id f5mr5772450pjh.92.1634717768372; Wed, 20 Oct 2021 01:16:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1634717768; cv=none; d=google.com; s=arc-20160816; b=uHUXhVcCpb5Ba/prC1OcJL/12SoZOo3i+l8Ok57JkvOEuMRPTPXz0dDXdClNEAFirI tYubzttY/rWYK2YRMgigunNymOvuXVQId8+2Au2/eqRwb4EVeg2P1CCpavy51Sk+NIBo gGpvoBTRyd/4t4wQz3T1EoHSeCmI2u1iFXb4uOJulWS+u80PbhKcBwIJhxOKUFhWwzl+ glCuPRCF/A9O3yvGvqO+pJsRE7mdwYBbzSZE4ZwT+kh70wk7C3xNhBtvDPZTdq9bvJUp /zgyGeql7k+fIvlL4K4m0nQ3FPrwP6sFROMTZv5qBIokI7t/kS9L2gM2hEUjKepCxsn0 XFyw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :mime-version:accept-language:in-reply-to:references:message-id:date :thread-index:thread-topic:subject:cc:to:from; bh=kgj19h/m8a/YKHwWE77+yeEmqPvCK3gM1iYsWlFA1mA=; b=RuTT8jLyjgJ8rpoinwgSX5atyTnaSbmw9Aw14k0JmCkfDNpMW9Dd7CZBLZJe0mS58v kkJ4/wjFh1ncyFVEgEVQ5HPXJupa/QAmdV++rELWUBgwOowmpVVutd3/mB0HZpTo4NHT jPHsrlHPuX171ewLu5U7E46JR8k+tHF/9iPsG9DwsnHdxGoOk4hx0IAEJirL+YaHUZda IoQA5wFL14CkWIOvXYg7CfHnNELC3IFFnIMsQcAxUPjhbq4tvtDbVreUY+ng7id/tBSR pw41k/0AGb4jzVZkQChMYg05wU4OIZFyiLeMxlrQq6hABLCdOdq7mvpJmWxuN8G/Kj5P J2Lw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=aculab.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id d17si2101876pgj.581.2021.10.20.01.15.55; Wed, 20 Oct 2021 01:16:08 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=aculab.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229632AbhJTIRH convert rfc822-to-8bit (ORCPT + 99 others); Wed, 20 Oct 2021 04:17:07 -0400 Received: from eu-smtp-delivery-151.mimecast.com ([185.58.85.151]:51874 "EHLO eu-smtp-delivery-151.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229548AbhJTIRB (ORCPT ); Wed, 20 Oct 2021 04:17:01 -0400 Received: from AcuMS.aculab.com (156.67.243.121 [156.67.243.121]) (Using TLS) by relay.mimecast.com with ESMTP id uk-mta-264-cXpa1CEUN6Sk8MILzfGu8g-1; Wed, 20 Oct 2021 09:14:44 +0100 X-MC-Unique: cXpa1CEUN6Sk8MILzfGu8g-1 Received: from AcuMS.Aculab.com (fd9f:af1c:a25b:0:994c:f5c2:35d6:9b65) by AcuMS.aculab.com (fd9f:af1c:a25b:0:994c:f5c2:35d6:9b65) with Microsoft SMTP Server (TLS) id 15.0.1497.23; Wed, 20 Oct 2021 09:14:42 +0100 Received: from AcuMS.Aculab.com ([fe80::994c:f5c2:35d6:9b65]) by AcuMS.aculab.com ([fe80::994c:f5c2:35d6:9b65%12]) with mapi id 15.00.1497.023; Wed, 20 Oct 2021 09:14:42 +0100 From: David Laight To: 'Nathan Chancellor' , Greg Kroah-Hartman CC: Nick Desaulniers , "linux-staging@lists.linux.dev" , "linux-kernel@vger.kernel.org" , "llvm@lists.linux.dev" Subject: RE: [PATCH] staging: wlan-ng: Avoid bitwise vs logical OR warning in hfa384x_usb_throttlefn() Thread-Topic: [PATCH] staging: wlan-ng: Avoid bitwise vs logical OR warning in hfa384x_usb_throttlefn() Thread-Index: AQHXwUZ2FnqdAiWt8EaCTgFmgVgUJ6vbkYrw Date: Wed, 20 Oct 2021 08:14:42 +0000 Message-ID: References: <20211014215703.3705371-1-nathan@kernel.org> In-Reply-To: <20211014215703.3705371-1-nathan@kernel.org> Accept-Language: en-GB, en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-ms-exchange-transport-fromentityheader: Hosted x-originating-ip: [10.202.205.107] MIME-Version: 1.0 Authentication-Results: relay.mimecast.com; auth=pass smtp.auth=C51A453 smtp.mailfrom=david.laight@aculab.com X-Mimecast-Spam-Score: 0 X-Mimecast-Originator: aculab.com Content-Language: en-US Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8BIT Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Nathan Chancellor > Sent: 14 October 2021 22:57 > > A new warning in clang points out a place in this file where a bitwise > OR is being used with boolean expressions: > > In file included from drivers/staging/wlan-ng/prism2usb.c:2: > drivers/staging/wlan-ng/hfa384x_usb.c:3787:7: warning: use of bitwise '|' with boolean operands [- > Wbitwise-instead-of-logical] > ((test_and_clear_bit(THROTTLE_RX, &hw->usb_flags) && > ~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ > drivers/staging/wlan-ng/hfa384x_usb.c:3787:7: note: cast one or both operands to int to silence this > warning > 1 warning generated. > > The comment explains that short circuiting here is undesirable, as the > calls to test_and_{clear,set}_bit() need to happen for both sides of the > expression. > > Clang's suggestion would work to silence the warning but the readability > of the expression would suffer even more. To clean up the warning and > make the block more readable, use a variable for each side of the > bitwise expression. > > Link: https://github.com/ClangBuiltLinux/linux/issues/1478 > Signed-off-by: Nathan Chancellor > --- > drivers/staging/wlan-ng/hfa384x_usb.c | 22 +++++++++++----------- > 1 file changed, 11 insertions(+), 11 deletions(-) > > diff --git a/drivers/staging/wlan-ng/hfa384x_usb.c b/drivers/staging/wlan-ng/hfa384x_usb.c > index 59aa84d1837d..938e11a1a0b6 100644 > --- a/drivers/staging/wlan-ng/hfa384x_usb.c > +++ b/drivers/staging/wlan-ng/hfa384x_usb.c > @@ -3778,18 +3778,18 @@ static void hfa384x_usb_throttlefn(struct timer_list *t) > > spin_lock_irqsave(&hw->ctlxq.lock, flags); > > - /* > - * We need to check BOTH the RX and the TX throttle controls, > - * so we use the bitwise OR instead of the logical OR. > - */ > pr_debug("flags=0x%lx\n", hw->usb_flags); > - if (!hw->wlandev->hwremoved && > - ((test_and_clear_bit(THROTTLE_RX, &hw->usb_flags) && > - !test_and_set_bit(WORK_RX_RESUME, &hw->usb_flags)) | > - (test_and_clear_bit(THROTTLE_TX, &hw->usb_flags) && > - !test_and_set_bit(WORK_TX_RESUME, &hw->usb_flags)) > - )) { > - schedule_work(&hw->usb_work); > + if (!hw->wlandev->hwremoved) { > + bool rx_throttle = test_and_clear_bit(THROTTLE_RX, &hw->usb_flags) && > + !test_and_set_bit(WORK_RX_RESUME, &hw->usb_flags); > + bool tx_throttle = test_and_clear_bit(THROTTLE_TX, &hw->usb_flags) && > + !test_and_set_bit(WORK_TX_RESUME, &hw->usb_flags); > + /* > + * We need to check BOTH the RX and the TX throttle controls, > + * so we use the bitwise OR instead of the logical OR. > + */ > + if (rx_throttle | tx_throttle) > + schedule_work(&hw->usb_work); Why not the slightly simpler: bool throttle = test_and_clear_bit(THROTTLE_RX, &hw->usb_flags) && !test_and_set_bit(WORK_RX_RESUME, &hw->usb_flags); throttle |= test_and_clear_bit(THROTTLE_TX, &hw->usb_flags) && !test_and_set_bit(WORK_TX_RESUME, &hw->usb_flags); if (throttle) schedule_work(&hw->usb_work); or with s/throttle/throttle_silly_compiler_warning/ :-) David - Registered Address Lakeside, Bramley Road, Mount Farm, Milton Keynes, MK1 1PT, UK Registration No: 1397386 (Wales)