Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp3033403ybt; Mon, 29 Jun 2020 13:27:40 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxF99MkZgWZKhSXL8fyOoDZQVJ7W8hZHR+L8UW3SdOF7Rw6MgaDcl1PPztf0LsoOIO1uzGc X-Received: by 2002:a17:906:2a5b:: with SMTP id k27mr15003330eje.82.1593462460409; Mon, 29 Jun 2020 13:27:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593462460; cv=none; d=google.com; s=arc-20160816; b=vTwBzICUZ3h0gJQjmAGYl6OHz1yFuvX7Rzv6vgv9BqZTF2WVmIMkZoWcapmqYqCDSI DCZKOD+ETYkCSRqHzY7XkWPnSxqBCSAxDV28vtDva2b8HDAZXIGEwelimgXDiku92/2W PQYrbgy1VYsLWOTsU5cEToUP/0tUS4wQTl5yTDHmhGnTLGGf0ZlIt4RujqDkTrQ4MpDI xMSEvuwM3CzW0FXj0xdklc1i7aXJuFnAgLPBfady8KmiY8Zr1yPwhsRKKc/izcqogyvb ueSRzm3+kfVbt5QDkFbMVgZ1ZYGL8Q0e2u9dmx2uyVp52BOtCExGcLKUWW5KhN5xSA/B PrCw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=ov8IAv5lPjXhMZh5ftLAA8YQZ9cE4vXrTckrujj9/wY=; b=V+FfewzZNiBj/q/DMn5AxNTnAu6mZCgtPTaB7wZ/F6HNt9G2syDAkYO5FPH8BGjW/v 3vjrQwhzqWJ5eh8SLzz/nGaQuhcx09w/bHymZwHoZYNholVIrLicM0mJdPjrDYYNqHvA vXM1I7EcXosXeEZ/s3JZ2A3G4Tyhdw1dApLIQ89SyiRka4MEeiNK6aZ0LktxQclVJJub a69Ogl33Wo5hrjYyfviAF4gKmhcAO2QVx+GeqNFx7pSd+8b8q1249rr8aIi9ZZUP4J7j 3OQTg6D40iAE6ZPKd7RfdFUDwN3Fmc3mc+M3Usr8NyozCN0bj1kAPV1Np/khMRbLbu9D /89w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=IaD60DIE; 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=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id n20si351592ejs.158.2020.06.29.13.27.17; Mon, 29 Jun 2020 13:27:40 -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=@kernel.org header.s=default header.b=IaD60DIE; 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=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2389029AbgF2UZz (ORCPT + 99 others); Mon, 29 Jun 2020 16:25:55 -0400 Received: from mail.kernel.org ([198.145.29.99]:37022 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732534AbgF2TZ1 (ORCPT ); Mon, 29 Jun 2020 15:25:27 -0400 Received: from sasha-vm.mshome.net (c-73-47-72-35.hsd1.nh.comcast.net [73.47.72.35]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 752812545D; Mon, 29 Jun 2020 15:43:32 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1593445413; bh=bK43YyasDjA+nH/El0kOebEyB1q57XCqJhlpWhWcKUY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=IaD60DIEIVN4uHmBOaJXL5TcfoZ+VW0D4g3urksYKKlfmWLhvMvQuhmU6QkdROpIp ZiCiK5T/eHyvVSpAnvO6AAREKMWpfF26XiJ0GKGMPvmtmDwXy/fT+Ywe0nz0hvd4D2 l75jdatXj6PJ+YaCn27dp9Zi2guIp/CMWDztzgp0= From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Alexander Lobakin , Igor Russkikh , Michal Kalderon , "David S . Miller" , Sasha Levin Subject: [PATCH 4.9 163/191] net: qed: fix left elements count calculation Date: Mon, 29 Jun 2020 11:39:39 -0400 Message-Id: <20200629154007.2495120-164-sashal@kernel.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20200629154007.2495120-1-sashal@kernel.org> References: <20200629154007.2495120-1-sashal@kernel.org> MIME-Version: 1.0 X-KernelTest-Patch: http://kernel.org/pub/linux/kernel/v4.x/stable-review/patch-4.9.229-rc1.gz X-KernelTest-Tree: git://git.kernel.org/pub/scm/linux/kernel/git/stable/linux-stable-rc.git X-KernelTest-Branch: linux-4.9.y X-KernelTest-Patches: git://git.kernel.org/pub/scm/linux/kernel/git/stable/stable-queue.git X-KernelTest-Version: 4.9.229-rc1 X-KernelTest-Deadline: 2020-07-01T15:39+00:00 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Alexander Lobakin [ Upstream commit 97dd1abd026ae4e6a82fa68645928404ad483409 ] qed_chain_get_element_left{,_u32} returned 0 when the difference between producer and consumer page count was equal to the total page count. Fix this by conditional expanding of producer value (vs unconditional). This allowed to eliminate normalizaton against total page count, which was the cause of this bug. Misc: replace open-coded constants with common defines. Fixes: a91eb52abb50 ("qed: Revisit chain implementation") Signed-off-by: Alexander Lobakin Signed-off-by: Igor Russkikh Signed-off-by: Michal Kalderon Signed-off-by: David S. Miller Signed-off-by: Sasha Levin --- include/linux/qed/qed_chain.h | 26 ++++++++++++++++---------- 1 file changed, 16 insertions(+), 10 deletions(-) diff --git a/include/linux/qed/qed_chain.h b/include/linux/qed/qed_chain.h index 72d88cf3ca25b..5a215da57b55a 100644 --- a/include/linux/qed/qed_chain.h +++ b/include/linux/qed/qed_chain.h @@ -155,28 +155,34 @@ static inline u32 qed_chain_get_cons_idx_u32(struct qed_chain *p_chain) static inline u16 qed_chain_get_elem_left(struct qed_chain *p_chain) { + u16 elem_per_page = p_chain->elem_per_page; + u32 prod = p_chain->u.chain16.prod_idx; + u32 cons = p_chain->u.chain16.cons_idx; u16 used; - used = (u16) (((u32)0x10000 + - (u32)p_chain->u.chain16.prod_idx) - - (u32)p_chain->u.chain16.cons_idx); + if (prod < cons) + prod += (u32)U16_MAX + 1; + + used = (u16)(prod - cons); if (p_chain->mode == QED_CHAIN_MODE_NEXT_PTR) - used -= p_chain->u.chain16.prod_idx / p_chain->elem_per_page - - p_chain->u.chain16.cons_idx / p_chain->elem_per_page; + used -= prod / elem_per_page - cons / elem_per_page; return (u16)(p_chain->capacity - used); } static inline u32 qed_chain_get_elem_left_u32(struct qed_chain *p_chain) { + u16 elem_per_page = p_chain->elem_per_page; + u64 prod = p_chain->u.chain32.prod_idx; + u64 cons = p_chain->u.chain32.cons_idx; u32 used; - used = (u32) (((u64)0x100000000ULL + - (u64)p_chain->u.chain32.prod_idx) - - (u64)p_chain->u.chain32.cons_idx); + if (prod < cons) + prod += (u64)U32_MAX + 1; + + used = (u32)(prod - cons); if (p_chain->mode == QED_CHAIN_MODE_NEXT_PTR) - used -= p_chain->u.chain32.prod_idx / p_chain->elem_per_page - - p_chain->u.chain32.cons_idx / p_chain->elem_per_page; + used -= (u32)(prod / elem_per_page - cons / elem_per_page); return p_chain->capacity - used; } -- 2.25.1