Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S933953AbcCPREW (ORCPT ); Wed, 16 Mar 2016 13:04:22 -0400 Received: from mail-by2on0101.outbound.protection.outlook.com ([207.46.100.101]:44101 "EHLO na01-by2-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1752890AbcCPREV convert rfc822-to-8bit (ORCPT ); Wed, 16 Mar 2016 13:04:21 -0400 From: Hartley Sweeten To: Arnd Bergmann CC: Ian Abbott , Greg Kroah-Hartman , Amitoj Kaur Chawla , Bhaktipriya Shridhar , "devel@driverdev.osuosl.org" , "linux-kernel@vger.kernel.org" Subject: RE: [PATCH] staging/comedi/dt282x: avoid integer overflow warning Thread-Topic: [PATCH] staging/comedi/dt282x: avoid integer overflow warning Thread-Index: AQHRfkOqoOuQ0v17NkiW6jbPL4yfgZ9bCEJQgAAEiACAAUDaEA== Date: Wed, 16 Mar 2016 17:04:15 +0000 Message-ID: References: <1457995713-1517950-1-git-send-email-arnd@arndb.de> <3577040.FW0X5IMTpl@wuerfel> In-Reply-To: <3577040.FW0X5IMTpl@wuerfel> Accept-Language: en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: authentication-results: arndb.de; dkim=none (message not signed) header.d=none;arndb.de; dmarc=none action=none header.from=visionengravers.com; x-originating-ip: [184.183.19.121] x-ms-office365-filtering-correlation-id: f8aa85a7-111e-4ae0-1287-08d34dbd012d x-microsoft-exchange-diagnostics: 1;BY1PR0101MB1063;5:Y7l4fpHURLx6/0VexOQeIFZCC01d5VBRgtD8pPop8v1dHED2nmeIUKuD8lHWhcqTpcwwt8/jr9o8NjFUx1c2cmLB1WAxB9ge2WhKsswqeBe/KFeHckl/ZlI4uMZ4uCZu5zbLrLpTLmhoekyE4HGjEw==;24:MPNm9+lNtnQiVhusYq4CyU0cEcxzetulHXBt/onTqj1OY6HgsUFPT14Q+nxoX+5bXoIjWyWE/1RYHD7Lfm9hRq7gStipBYPN37CQchaFqc0= x-microsoft-antispam: UriScan:;BCL:0;PCL:0;RULEID:;SRVR:BY1PR0101MB1063; x-microsoft-antispam-prvs: x-exchange-antispam-report-test: UriScan:; x-exchange-antispam-report-cfa-test: BCL:0;PCL:0;RULEID:(6040046)(2401047)(5005006)(8121501046)(10201501046)(3002001)(6041046)(6043046);SRVR:BY1PR0101MB1063;BCL:0;PCL:0;RULEID:;SRVR:BY1PR0101MB1063; x-forefront-prvs: 08831F51DC x-forefront-antispam-report: SFV:NSPM;SFS:(10019020)(6009001)(377454003)(24454002)(87936001)(10400500002)(86362001)(76176999)(5008740100001)(50986999)(575784001)(54356999)(106116001)(11100500001)(19580405001)(19580395003)(5002640100001)(5004730100002)(122556002)(33656002)(110136002)(5003600100002)(4326007)(80792005)(189998001)(3660700001)(6116002)(2900100001)(77096005)(2906002)(81166005)(3280700002)(586003)(1096002)(3846002)(1220700001)(92566002)(74316001)(2950100001)(102836003)(66066001);DIR:OUT;SFP:1102;SCL:1;SRVR:BY1PR0101MB1063;H:BY1PR0101MB1063.prod.exchangelabs.com;FPR:;SPF:None;MLV:sfv;LANG:en; spamdiagnosticoutput: 1:23 spamdiagnosticmetadata: NSPM Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 8BIT MIME-Version: 1.0 X-OriginatorOrg: visionengravers.com X-MS-Exchange-CrossTenant-originalarrivaltime: 16 Mar 2016 17:04:15.1541 (UTC) X-MS-Exchange-CrossTenant-fromentityheader: Hosted X-MS-Exchange-CrossTenant-id: d698601f-af92-4269-8099-fd6f11636477 X-MS-Exchange-Transport-CrossTenantHeadersStamped: BY1PR0101MB1063 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2021 Lines: 56 On Tuesday, March 15, 2016 2:50 PM, Arnd Bergmann wrote: > On Tuesday 15 March 2016 21:35:40 Hartley Sweeten wrote: >> On Monday, March 14, 2016 3:48 PM, Arnd Bergmann wrote: >>> gcc-6 warns about passing negative signed integer into swab16() >>> in the dt282x driver: >> >> >> >>> The warning makes sense, though the code is correct as far as I >>> can tell. >>> >>> This disambiguates the operation by making the constant expressions >>> we pass here explicitly 'unsigned', which helps to avoid the warning. >>> >>> Signed-off-by: Arnd Bergmann >>> --- >>> drivers/staging/comedi/drivers/dt282x.c | 62 ++++++++++++++++----------------- >>> 1 file changed, 31 insertions(+), 31 deletions(-) >>> >>> diff --git a/drivers/staging/comedi/drivers/dt282x.c b/drivers/staging/comedi/drivers/dt282x.c >>> index 40bf00984fa5..d4d45c759c62 100644 >>> --- a/drivers/staging/comedi/drivers/dt282x.c >>> +++ b/drivers/staging/comedi/drivers/dt282x.c >>> @@ -69,48 +69,48 @@ >>> * Register map >>> */ >>> #define DT2821_ADCSR_REG 0x00 >> -#define DT2821_ADCSR_ADERR (1 << 15) >>> -#define DT2821_ADCSR_ADCLK (1 << 9) >>> -#define DT2821_ADCSR_MUXBUSY (1 << 8) >>> -#define DT2821_ADCSR_ADDONE (1 << 7) >>> -#define DT2821_ADCSR_IADDONE (1 << 6) >>> +#define DT2821_ADCSR_ADERR (1u << 15) >> >> Changing all of these to use the BIT() macro should also avoid the warning. > > Yes, but it won't work for the ones that have more than one bit: > > #define DT2821_SUPCSR_DS_AD_TRIG (3 << 10) Use a helper macro for those bits: #define DT2821_SUPCSR_DS(x) (((x) & 0x3) << 10) #define DT2821_SUPCSR_DS_PIO DT2821_SUPCSR_DS(0) #define DT2821_SUPCSR_DS_AD_CLK DT2821_SUPCSR_DS(1) #define DT2821_SUPCSR_DS_DA_CLK DT2821_SUPCSR_DS(2) #define DT2821_SUPCSR_DS_AD_TRIG DT2821_SUPCSR_DS(3) > I considered using BIT() but decided against it for consistency. Your change may fix the gcc-6 issue but it doesn't fix the 28 checkpatch.pl issues: CHECK: Prefer using the BIT macro Regards, Hartley