Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp4560751pxj; Wed, 12 May 2021 08:13:06 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzaybvUD1aki9YEFrhUc3T5LfKvhVzXj9gOSCBy1VcP2WBBHFzsuhGeQ4FV9qSmHHqMnOK4 X-Received: by 2002:a9d:7852:: with SMTP id c18mr30271381otm.115.1620832386781; Wed, 12 May 2021 08:13:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620832386; cv=none; d=google.com; s=arc-20160816; b=N1+iDr88brXIlk1JcMKJD6zydDcVI6CZ7Cmb6uIgrWT5YKX70N82BUZ4UfQnz1YUqi YpiRBbFEH3lXLjmtTCAieyvRyRZGs5Hxb2ERQCKjSlxNbfF4Miebq34XRjNcmgup6tbR Pe4rHkRivr2PBUwdizzLhJEWjOG1SYynzVs4c9zmytWv3Whx+6mZY3U+PbjB4NYgOUkR snhvabFXssxN2jiRi0EHPnNEcwne9UP1CCmfvcZI3L3I6BCexMmBrnqNeyk3OFW9BS0r n9UEmkAf/H6ISawUpqqzay9bpqt1UrJT1dr2z0I9ebdZT4qo3QqwIHODYeTJDbBtBz7g 6bCA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=7Hn+CNA/od2iiWvjV0g5aEQaFXL+eY+gs+CBeivDkzk=; b=WlGKo+iQBUxfiowjrWhqkL2j2IeNOJDXZD/lcZe6zj0ntZf5F0eXyCPnRTYXmvG8l/ 86v6OC7DNgB+XhsroibpqFE3PKYbrCJEvM74yGbPo7uAWlrDMiC86cIBd18JABXJYqOt 7QsBYIVyGMZF5VpdltVzDvhoP+wsM3FVchDFKEHTyMQC/1jBL+FqS/XFKFoVi1yZLbMn NRfOdh0wmRHrL50pUrl99PVBkTB/qlswbULBBrhPoLRCgti90TURL83SNZyO4HdC0pDx eqGLh5ucb0yxbU2nwd8SPrg7JxZLqL+0lmLIB++N4/cVJsoBqOw2g/wMbADTkDfMO74U D6HQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=ZNUYAIAy; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id v16si140575ota.243.2021.05.12.08.12.53; Wed, 12 May 2021 08:13:06 -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; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=ZNUYAIAy; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232227AbhELPNM (ORCPT + 99 others); Wed, 12 May 2021 11:13:12 -0400 Received: from mail.kernel.org ([198.145.29.99]:58748 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233357AbhELPFP (ORCPT ); Wed, 12 May 2021 11:05:15 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id CA76261945; Wed, 12 May 2021 15:00:03 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1620831604; bh=uidAe+Es+/+PmreWX+fJb2EbtdDpLV3OhFvWEUt83cY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=ZNUYAIAydNFXYr2WqT4W+gIv63NauAjserPIRDQLVrseg/p3A6GC7ZR5fGPog9y+f wDgZB6bX3OyLDReCQgEPZZeK+WUiFmFn2gEsD0Yy55+1mXuu8CCIflO203MAs8A0Ec b1Wl5+hjdkOm8n6Fqz5Zosb4ywbSizvrQZZFjonQ= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Colin Ian King , "David S. Miller" , Sasha Levin Subject: [PATCH 5.4 185/244] liquidio: Fix unintented sign extension of a left shift of a u16 Date: Wed, 12 May 2021 16:49:16 +0200 Message-Id: <20210512144748.914772230@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210512144743.039977287@linuxfoundation.org> References: <20210512144743.039977287@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Colin Ian King [ Upstream commit 298b58f00c0f86868ea717426beb5c1198772f81 ] The macro CN23XX_PEM_BAR1_INDEX_REG is being used to shift oct->pcie_port (a u16) left 24 places. There are two subtle issues here, first the shift gets promoted to an signed int and then sign extended to a u64. If oct->pcie_port is 0x80 or more then the upper bits get sign extended to 1. Secondly shfiting a u16 24 bits will lead to an overflow so it needs to be cast to a u64 for all the bits to not overflow. It is entirely possible that the u16 port value is never large enough for this to fail, but it is useful to fix unintended overflows such as this. Fix this by casting the port parameter to the macro to a u64 before the shift. Addresses-Coverity: ("Unintended sign extension") Fixes: 5bc67f587ba7 ("liquidio: CN23XX register definitions") Signed-off-by: Colin Ian King Signed-off-by: David S. Miller Signed-off-by: Sasha Levin --- drivers/net/ethernet/cavium/liquidio/cn23xx_pf_regs.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/net/ethernet/cavium/liquidio/cn23xx_pf_regs.h b/drivers/net/ethernet/cavium/liquidio/cn23xx_pf_regs.h index e6d4ad99cc38..3f1c189646f4 100644 --- a/drivers/net/ethernet/cavium/liquidio/cn23xx_pf_regs.h +++ b/drivers/net/ethernet/cavium/liquidio/cn23xx_pf_regs.h @@ -521,7 +521,7 @@ #define CN23XX_BAR1_INDEX_OFFSET 3 #define CN23XX_PEM_BAR1_INDEX_REG(port, idx) \ - (CN23XX_PEM_BAR1_INDEX_START + ((port) << CN23XX_PEM_OFFSET) + \ + (CN23XX_PEM_BAR1_INDEX_START + (((u64)port) << CN23XX_PEM_OFFSET) + \ ((idx) << CN23XX_BAR1_INDEX_OFFSET)) /*############################ DPI #########################*/ -- 2.30.2