Received: by 2002:a05:6a10:a841:0:0:0:0 with SMTP id d1csp614316pxy; Thu, 22 Apr 2021 09:23:24 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxtxdiZHPIETnaBfZTgiU6nRhvec1U0o1VN/Tw4wmoiwx8ABT2Ewi3rHRjLTj3Op4a+L/TC X-Received: by 2002:a05:6402:1a52:: with SMTP id bf18mr4920236edb.289.1619108603972; Thu, 22 Apr 2021 09:23:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1619108603; cv=none; d=google.com; s=arc-20160816; b=eWpkyd4rWFyiaa3GZSz4PZLkUMvhWWWIkOgTYhtW9IstfLc5Qcx9hog6Oxb8qlaymJ JDU2MEYle6KT9Ot5zrXYsNSEg9V9lx01piHYI6CwUnF9orePilQm9VhwvzjXtKXxRhSt nkomm1xnbas5TdFv3ViNBt7IWvjqSPoj650BC05fz1LULvievh8zCMNkXJD6hiXzrlw+ RVdkEAOHFF5LnqvnkNeQL4onQqT+Srqjs9mPNyZblivDU4oAHtqG5nuua0tmcFy+2lXH 5j5Jd/kj66Em2YCNk2iKVbXIjvTwkzJQ26/c82S6IrEveBJnAc7rdrmGa72fYz7HrcCW SYOw== 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=XHhTXuhpmGOEkmh84kpvpr/RVfsx02BUYG9ynaTB8H4=; b=SfKj2YGQHkJtSAiAJpF7One57oAa/TDO0mr3zfMKvZ8Q0nihmNmN9W+JNz8P2XV/ew 3yDJ1Dcm4rgQ7mn2xm+QfoxJGuDWh9//GR83j88JZsPY1kyVH7Uw59TjRnXs/FmJiiXC Ly4x0zz653sG49MfZyaHmdI7EZQl0DoHU+fFzL/GKIjZIeiEmeip/osdH7YrIk5SV9Yv Wy3EqHSbpQrRYAi3SyeNtSYrggj5fjBMlCzeyLsrexS15iaZGdJvTZF+cv9pdG+VA+IM r3qulhCk6BP8Qha10uzNvIeFIKoXQmi/nUx4hJjwHBLx139BnFIF0VW1snEL9Fdodxv9 TYWg== 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 jz7si2699321ejc.96.2021.04.22.09.22.59; Thu, 22 Apr 2021 09:23:23 -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 S236571AbhDVQWV convert rfc822-to-8bit (ORCPT + 99 others); Thu, 22 Apr 2021 12:22:21 -0400 Received: from eu-smtp-delivery-151.mimecast.com ([185.58.85.151]:47292 "EHLO eu-smtp-delivery-151.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236236AbhDVQWT (ORCPT ); Thu, 22 Apr 2021 12:22:19 -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-270-mhKvP-dDOsuLyQ0QyQj3_Q-1; Thu, 22 Apr 2021 17:21:41 +0100 X-MC-Unique: mhKvP-dDOsuLyQ0QyQj3_Q-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.2; Thu, 22 Apr 2021 17:21:40 +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.015; Thu, 22 Apr 2021 17:21:40 +0100 From: David Laight To: 'Dan Carpenter' , Joel Stanley CC: Andrew Jeffery , "Chia-Wei, Wang" , Jae Hyun Yoo , "John Wang" , Brad Bishop , Patrick Venture , "Benjamin Fair" , Greg Kroah-Hartman , Robert Lippert , "linux-aspeed@lists.ozlabs.org" , "linux-kernel@vger.kernel.org" , "kernel-janitors@vger.kernel.org" Subject: RE: [PATCH] soc: aspeed: fix a ternary sign expansion bug Thread-Topic: [PATCH] soc: aspeed: fix a ternary sign expansion bug Thread-Index: AQHXN1ec+IlNNgnl7EGootyN/jCOrarAtu4w Date: Thu, 22 Apr 2021 16:21:40 +0000 Message-ID: <59596244622c4a15ac8cc0747332d0be@AcuMS.aculab.com> References: In-Reply-To: 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: Dan Carpenter > Sent: 22 April 2021 10:12 > > The intent here was to return negative error codes but it actually > returns positive values. The problem is that type promotion with > ternary operations is quite complicated. > > "ret" is an int. "copied" is a u32. And the snoop_file_read() function > returns long. What happens is that "ret" is cast to u32 and becomes > positive then it's cast to long and it's still positive. > > Fix this by removing the ternary so that "ret" is type promoted directly > to long. > > Fixes: 3772e5da4454 ("drivers/misc: Aspeed LPC snoop output using misc chardev") > Signed-off-by: Dan Carpenter > --- > drivers/soc/aspeed/aspeed-lpc-snoop.c | 4 +++- > 1 file changed, 3 insertions(+), 1 deletion(-) > > diff --git a/drivers/soc/aspeed/aspeed-lpc-snoop.c b/drivers/soc/aspeed/aspeed-lpc-snoop.c > index 210455efb321..eceeaf8dfbeb 100644 > --- a/drivers/soc/aspeed/aspeed-lpc-snoop.c > +++ b/drivers/soc/aspeed/aspeed-lpc-snoop.c > @@ -94,8 +94,10 @@ static ssize_t snoop_file_read(struct file *file, char __user *buffer, > return -EINTR; > } > ret = kfifo_to_user(&chan->fifo, buffer, count, &copied); > + if (ret) > + return ret; > > - return ret ? ret : copied; > + return copied; I wonder if changing it to: return ret ? ret + 0L : copied; Might make people think in the future and not convert it back as an 'optimisation'. I much prefer adding 0 to a cast to fix integer types. In can go less wrong! IMHO there are far too many casts in the kernel sources. Especially the ones that are only there to appease sparse. A functional notation for those would remove some of the potential problems. David - Registered Address Lakeside, Bramley Road, Mount Farm, Milton Keynes, MK1 1PT, UK Registration No: 1397386 (Wales)