Received: by 2002:ac0:946b:0:0:0:0:0 with SMTP id j40csp2211117imj; Mon, 18 Feb 2019 01:53:13 -0800 (PST) X-Google-Smtp-Source: AHgI3Iah8c+J6rNpEDyFw6YSPnZB7MBaa/7DxhJwiBJhJB/c6DB7G8xXqdYF8MFdDqf+j0GEgxkh X-Received: by 2002:aa7:85cc:: with SMTP id z12mr23547218pfn.196.1550483593067; Mon, 18 Feb 2019 01:53:13 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1550483593; cv=none; d=google.com; s=arc-20160816; b=RELB0hYr+mlu9j3f6urYVRLFP0txB6FjwMC4WwXyQfmJEeS5hS7IMTyTkokfcZcICp a6AAiQmphwOhKDyVJkbUbi2bUmQ9y5LohcCS68j5sn1UsOWDYmhb27z0XdyKStuDn4ri JlOlu5PiSDQ4UWE++QJRa6I57KZcV2dA2jXhJVrwCw0Y4inNI9eVGG1yNUfrQBDoasE6 OTN3K6GvSvVzA7xGUX088WYe6+8KhLvEBAJPCg2KvgUAWimDiQA7tlmN8Q4uvvIOOK/N wAdqCZOM4hjJ6VBj2MRdbQc8oo3FHjkY55UVqv2GSVfb1aefQUD41yiLYOkMIUHmbCT2 EvcA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=S7BpYWvWJfJZDRrSk/Ev/sZMj8iLn7HBry9NGkvBct8=; b=HHCkeH/rIS4E3wqAWt67jJT9irGLuKGr1QlXkp8UgeCHRhS4HeWsqZTKXxMG9gUS3H 4Vb/aAqXghGjTIHfldpbHmPbFEUEpzH2Jww0C3loMCPgfJCIjBfsoWe+R2bv56cYSPIR 9m4aWhXJPVqdSqg6GGrgBHM87j0K4TjfP7qz0fgw/qWqPvj5pPvWnOReJP1kuBEkc85L LxHST92e0GFbJmbdMvqwnNMMXMjJZQS1OmX8N0cysPlRq7joFoP2Jof5J3XTNpQoA/Kd CA+fl/9mCzTA6j9FpJTaPuFf813pcNfFbVquYe0jiEP7kB2cuunw5Zz/BB9gaICLSbds dAKQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@oracle.com header.s=corp-2018-07-02 header.b=1pNxpUqH; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=oracle.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id z13si6251559pgv.508.2019.02.18.01.52.57; Mon, 18 Feb 2019 01:53:13 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@oracle.com header.s=corp-2018-07-02 header.b=1pNxpUqH; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=oracle.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729723AbfBRJhk (ORCPT + 99 others); Mon, 18 Feb 2019 04:37:40 -0500 Received: from userp2120.oracle.com ([156.151.31.85]:43686 "EHLO userp2120.oracle.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729706AbfBRJhj (ORCPT ); Mon, 18 Feb 2019 04:37:39 -0500 Received: from pps.filterd (userp2120.oracle.com [127.0.0.1]) by userp2120.oracle.com (8.16.0.27/8.16.0.27) with SMTP id x1I9YJDQ013053; Mon, 18 Feb 2019 09:37:31 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oracle.com; h=date : from : to : cc : subject : message-id : references : mime-version : content-type : in-reply-to; s=corp-2018-07-02; bh=S7BpYWvWJfJZDRrSk/Ev/sZMj8iLn7HBry9NGkvBct8=; b=1pNxpUqH7lsvoKOh9P0ngvXRT2f/jBttQRlnKQ5II3be+v8bf7TxPtu5rpyQkOPkytUb 3yaLus7zvQpCAH+vuqky/UKNVUnQFDNLCraDg9tusvw/SsXAL59M8haikJXflDI6vVcE l6CA0PBSB0vDMeiHCJZ42m53DUhiy4MEuGwim3ACHHrA0rVdcCt818IEvTTi2cU0d/Et MzDpCKWuSn5ZUaRUPmXKhxtNqhyYQ1jaLJUJQgkIG2q3YcdvjPIhSi4Oj92aTocco9co buTi6R/yqIAS6x2jYZXsj6G1nQEg0KzOMKbOzbC8DK1+zqrAHeIqeM1FXRqKeMi7Dqxw hw== Received: from aserv0021.oracle.com (aserv0021.oracle.com [141.146.126.233]) by userp2120.oracle.com with ESMTP id 2qpb5r530s-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Mon, 18 Feb 2019 09:37:31 +0000 Received: from userv0121.oracle.com (userv0121.oracle.com [156.151.31.72]) by aserv0021.oracle.com (8.14.4/8.14.4) with ESMTP id x1I9bP2r015692 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Mon, 18 Feb 2019 09:37:25 GMT Received: from abhmp0001.oracle.com (abhmp0001.oracle.com [141.146.116.7]) by userv0121.oracle.com (8.14.4/8.13.8) with ESMTP id x1I9bLpZ015348; Mon, 18 Feb 2019 09:37:21 GMT Received: from kadam (/197.157.0.22) by default (Oracle Beehive Gateway v4.0) with ESMTP ; Mon, 18 Feb 2019 01:37:21 -0800 Date: Mon, 18 Feb 2019 12:37:10 +0300 From: Dan Carpenter To: Walter Harms Cc: Colin King , Jianyun Li , "James E . J . Bottomley" , "Martin K . Petersen" , linux-scsi@vger.kernel.org, kernel-janitors@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] scsi: mvumi: fix 32 bit shift of a 32 bit unsigned int Message-ID: <20190218093710.GB17104@kadam> References: <1596625925.142066.1550334436646@ox-groupware.bfs.de> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1596625925.142066.1550334436646@ox-groupware.bfs.de> User-Agent: Mutt/1.9.4 (2018-02-28) X-Proofpoint-Virus-Version: vendor=nai engine=5900 definitions=9170 signatures=668683 X-Proofpoint-Spam-Details: rule=notspam policy=default score=0 priorityscore=1501 malwarescore=0 suspectscore=2 phishscore=0 bulkscore=0 spamscore=0 clxscore=1011 lowpriorityscore=0 mlxscore=0 impostorscore=0 mlxlogscore=999 adultscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1810050000 definitions=main-1902180074 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sat, Feb 16, 2019 at 05:27:16PM +0100, Walter Harms wrote: > Am 16.02.2019 15:44, schrieb Colin King: > > From: Colin Ian King > > > > Currently m_sg->baseaddr_h (a 32 bit unsigned int) is being shifted by a > > total of 32 bits; this always produces a 0 result. Fix this by casting > > it to a dma_addr_t (a 64 bit unsigned int) before performing the shift. > > > > Detected by CoverityScan, CID#147270 ("Operands don't affect result") > > > > Fixes: f0c568a478f0 ("[SCSI] mvumi: Add Marvell UMI driver") > > Signed-off-by: Colin Ian King > > --- > > drivers/scsi/mvumi.c | 2 +- > > 1 file changed, 1 insertion(+), 1 deletion(-) > > > > diff --git a/drivers/scsi/mvumi.c b/drivers/scsi/mvumi.c > > index 36f64205ecfa..d3582accfd09 100644 > > --- a/drivers/scsi/mvumi.c > > +++ b/drivers/scsi/mvumi.c > > @@ -313,7 +313,7 @@ static void mvumi_delete_internal_cmd(struct mvumi_hba > > *mhba, > > sgd_getsz(mhba, m_sg, size); > > > > phy_addr = (dma_addr_t) m_sg->baseaddr_l | > > - (dma_addr_t) ((m_sg->baseaddr_h << 16) << 16); > > + (((dma_addr_t) m_sg->baseaddr_h << 16) << 16); > > > > dma_free_coherent(&mhba->pdev->dev, size, cmd->data_buf, > > phy_addr); > > i would suggest to try a version with less casts to make it more readable > like this untested suggestion: > > phy_addr =(m_sg->baseaddr_h << 16)| m_sg->baseaddr_l; > phy_addr <<= 16; > That would be a behavior change but it also might be a bugfix? Why doesn't the code just do: phy_addr = ((dma_addr_t)m_sg->baseaddr_h << 32) | m_sg->baseaddr_l; (Probably they broke it up into two shifts to silence a GCC warning that the shift was wrong because of the missing cast?) regards, dan carpenter