Received: by 2002:ac8:4f8f:0:b0:429:955e:b7c6 with SMTP id j15csp6408qtw; Tue, 16 Jan 2024 13:04:15 -0800 (PST) X-Google-Smtp-Source: AGHT+IHhflfShz2AZbrGl8+dZEJAvmACwgJ3bUmk4ll6VWGEeEtmPKpVUOoAuqAR1mcH7/koyEXq X-Received: by 2002:a05:6871:4d2:b0:203:ec89:de1e with SMTP id n18-20020a05687104d200b00203ec89de1emr10672916oai.58.1705439055185; Tue, 16 Jan 2024 13:04:15 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1705439055; cv=pass; d=google.com; s=arc-20160816; b=hkyCfcvSBBJjWwDiCtvjRi94yBQt29EeJ5ESiT0XsVsam69PnQqJoWsaq7bdJ7AfHa iwg9FmD33i/ezpJQRnnlOm2XPAuTig/nVtXmOx2IXer9TCyGtpG9Yj7YM5KhY1B/0ohg fLjqHMhVJ9YcpLTK9WWXD4QdpOTDHI/vTmvEMEsiFpEBgdP2iaeEG0NyHxVCoKY90uTk TEw/UlhFT54kr3p3DsxOsvdofTKzIp3PCd+TBdFyySrG29LxO45nbfOnzl/IDHXWOSZy dvOAnTKFFLV5eeoQbECF/2KOQlUiOXsnkc0MA/hbTHQ1hyDuHBgZHmWNI5i+z0o6HmfF qauQ== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:in-reply-to:message-id :date:subject:cc:to:from:dkim-signature; bh=ZdT6DFirPkUU1kekeJpE28sns+hLnKLBvIWisaPLukU=; fh=QVn62kvoFs4/amPNDweZreYvthno6s6cNjvrvdfcNB4=; b=XeojkdLacHSvlXAdbEW4tylY4VzkgBVj26rMgEX198YZm+QT/HPsN6ByAslvYvf6OW xt5BkciOD1SS2pL/2maBZmQs30avN3l9JU5JzHIIFZX28f3zqMtAcqpNqZUjNwxBuF17 fA6gJ7Ey68biwImN98Jql54CjnvdnoOxaXhz+chvdaD8l9ycIHWiowajaCbSGsxOpK4x AM35Ik8ZqZ2yd0bI40K9cerEf3EK95M9T/lcKgI5WeG3Q6u4UxU4DRh6dRSLzcIqy4sE a1+J34BHPaHzSPE5BzP0ynKxiQfnA1YNJrKqpl+9G/nTWzZJAsel0iN3iNOSX58f+1L/ xXxg== ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=RATiBioN; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-27988-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-27988-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from sy.mirrors.kernel.org (sy.mirrors.kernel.org. [2604:1380:40f1:3f00::1]) by mx.google.com with ESMTPS id bj3-20020a056a02018300b005cf8b79e32bsi1598424pgb.119.2024.01.16.13.04.14 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 16 Jan 2024 13:04:15 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-27988-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) client-ip=2604:1380:40f1:3f00::1; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=RATiBioN; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-27988-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-27988-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sy.mirrors.kernel.org (Postfix) with ESMTPS id 7C34BB24312 for ; Tue, 16 Jan 2024 20:51:48 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 30E5F135406; Tue, 16 Jan 2024 19:52:54 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="RATiBioN" Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 43781137C4F; Tue, 16 Jan 2024 19:52:52 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1705434773; cv=none; b=XRDEZA0uNd0RJzf6Aqu02PwYoH1X2v0tSKbJhI6BAWYnkIp2NCj4MaoB1Txg7bIhjwng7K++Rkn11EqQEMhyN0QXSr+tJvrwhHW0IhtQfTE4xSiOzQqYwUwZLRhAlR1Wj7jHGTtLv4d/M4HZ1u+LYHoB+UDBUFKjAhCq4/nVxh0= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1705434773; c=relaxed/simple; bh=GWno6YTcGCRMF9sb2JjBbd94P2+qY1I5giHJTO8LkTY=; h=Received:DKIM-Signature:From:To:Cc:Subject:Date:Message-ID: X-Mailer:In-Reply-To:References:MIME-Version:X-stable: X-Patchwork-Hint:X-stable-base:Content-Transfer-Encoding; b=RSm7OR0zjmS6y1FOaRgfIFvXd2dZAKWqv0dObI4aeRf1r4jW9fG94acQgFYMgA+Act+RNDG1l8K1lyzJj6LhaaPycfh52YM3hLgUdgIRqsFOuW2cJTMDQ94vN6hSBxTUL+IIOF0NyTTi1rtljY0XzAqXgm1wdVOFEXf48yfNQsU= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=RATiBioN; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPSA id E31B1C433C7; Tue, 16 Jan 2024 19:52:50 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1705434772; bh=GWno6YTcGCRMF9sb2JjBbd94P2+qY1I5giHJTO8LkTY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=RATiBioNvKy519T/7xYEjKFRd8WrCiu8EMT4gKtu79p1BFbZL47iGkwiY6MvX1sn/ bFje7NJC1QRSBexMcEzLg+5k6sQ8+utU5cfDSuYYidQI6+q8zZHyLt7BTrk7KAmD+n l1SXBikDOQXh68VDM+z/+KcR2EPrT621C3QADF+tPkUDGkopAO8fdZj5mLypLwdeBO Ebb0P73ADkeqXLtFytFpyb5btfDHQ0bsiPsiCQ9C70Bxzr8ESUZaZXDIU6yDvtgcvF sHZlIS+9L09rt9nwp/H+TPAq2ZXqSRVF0PnFAqJLnqDityYKrZHRgggBrOS6ha5Pzt CmIqAlDbDdJ7g== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Tobias Waldekranz , Vladimir Oltean , Florian Fainelli , "David S . Miller" , Sasha Levin , andrew@lunn.ch, f.fainelli@gmail.com, olteanv@gmail.com, edumazet@google.com, kuba@kernel.org, pabeni@redhat.com, netdev@vger.kernel.org Subject: [PATCH AUTOSEL 6.6 076/104] net: dsa: mv88e6xxx: Fix mv88e6352_serdes_get_stats error path Date: Tue, 16 Jan 2024 14:46:42 -0500 Message-ID: <20240116194908.253437-76-sashal@kernel.org> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20240116194908.253437-1-sashal@kernel.org> References: <20240116194908.253437-1-sashal@kernel.org> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore X-stable-base: Linux 6.6.12 Content-Transfer-Encoding: 8bit From: Tobias Waldekranz [ Upstream commit fc82a08ae795ee6b73fb6b50785f7be248bec7b5 ] mv88e6xxx_get_stats, which collects stats from various sources, expects all callees to return the number of stats read. If an error occurs, 0 should be returned. Prevent future mishaps of this kind by updating the return type to reflect this contract. Reviewed-by: Vladimir Oltean Reviewed-by: Florian Fainelli Signed-off-by: Tobias Waldekranz Signed-off-by: David S. Miller Signed-off-by: Sasha Levin --- drivers/net/dsa/mv88e6xxx/chip.h | 4 ++-- drivers/net/dsa/mv88e6xxx/serdes.c | 10 +++++----- drivers/net/dsa/mv88e6xxx/serdes.h | 8 ++++---- 3 files changed, 11 insertions(+), 11 deletions(-) diff --git a/drivers/net/dsa/mv88e6xxx/chip.h b/drivers/net/dsa/mv88e6xxx/chip.h index 44383a03ef2f..c54d305a1d83 100644 --- a/drivers/net/dsa/mv88e6xxx/chip.h +++ b/drivers/net/dsa/mv88e6xxx/chip.h @@ -601,8 +601,8 @@ struct mv88e6xxx_ops { int (*serdes_get_sset_count)(struct mv88e6xxx_chip *chip, int port); int (*serdes_get_strings)(struct mv88e6xxx_chip *chip, int port, uint8_t *data); - int (*serdes_get_stats)(struct mv88e6xxx_chip *chip, int port, - uint64_t *data); + size_t (*serdes_get_stats)(struct mv88e6xxx_chip *chip, int port, + uint64_t *data); /* SERDES registers for ethtool */ int (*serdes_get_regs_len)(struct mv88e6xxx_chip *chip, int port); diff --git a/drivers/net/dsa/mv88e6xxx/serdes.c b/drivers/net/dsa/mv88e6xxx/serdes.c index 3b4b42651fa3..01ea53940786 100644 --- a/drivers/net/dsa/mv88e6xxx/serdes.c +++ b/drivers/net/dsa/mv88e6xxx/serdes.c @@ -177,8 +177,8 @@ static uint64_t mv88e6352_serdes_get_stat(struct mv88e6xxx_chip *chip, return val; } -int mv88e6352_serdes_get_stats(struct mv88e6xxx_chip *chip, int port, - uint64_t *data) +size_t mv88e6352_serdes_get_stats(struct mv88e6xxx_chip *chip, int port, + uint64_t *data) { struct mv88e6xxx_port *mv88e6xxx_port = &chip->ports[port]; struct mv88e6352_serdes_hw_stat *stat; @@ -187,7 +187,7 @@ int mv88e6352_serdes_get_stats(struct mv88e6xxx_chip *chip, int port, err = mv88e6352_g2_scratch_port_has_serdes(chip, port); if (err <= 0) - return err; + return 0; BUILD_BUG_ON(ARRAY_SIZE(mv88e6352_serdes_hw_stats) > ARRAY_SIZE(mv88e6xxx_port->serdes_stats)); @@ -429,8 +429,8 @@ static uint64_t mv88e6390_serdes_get_stat(struct mv88e6xxx_chip *chip, int lane, return reg[0] | ((u64)reg[1] << 16) | ((u64)reg[2] << 32); } -int mv88e6390_serdes_get_stats(struct mv88e6xxx_chip *chip, int port, - uint64_t *data) +size_t mv88e6390_serdes_get_stats(struct mv88e6xxx_chip *chip, int port, + uint64_t *data) { struct mv88e6390_serdes_hw_stat *stat; int lane; diff --git a/drivers/net/dsa/mv88e6xxx/serdes.h b/drivers/net/dsa/mv88e6xxx/serdes.h index aac95cab46e3..ff5c3ab31e15 100644 --- a/drivers/net/dsa/mv88e6xxx/serdes.h +++ b/drivers/net/dsa/mv88e6xxx/serdes.h @@ -127,13 +127,13 @@ unsigned int mv88e6390_serdes_irq_mapping(struct mv88e6xxx_chip *chip, int mv88e6352_serdes_get_sset_count(struct mv88e6xxx_chip *chip, int port); int mv88e6352_serdes_get_strings(struct mv88e6xxx_chip *chip, int port, uint8_t *data); -int mv88e6352_serdes_get_stats(struct mv88e6xxx_chip *chip, int port, - uint64_t *data); +size_t mv88e6352_serdes_get_stats(struct mv88e6xxx_chip *chip, int port, + uint64_t *data); int mv88e6390_serdes_get_sset_count(struct mv88e6xxx_chip *chip, int port); int mv88e6390_serdes_get_strings(struct mv88e6xxx_chip *chip, int port, uint8_t *data); -int mv88e6390_serdes_get_stats(struct mv88e6xxx_chip *chip, int port, - uint64_t *data); +size_t mv88e6390_serdes_get_stats(struct mv88e6xxx_chip *chip, int port, + uint64_t *data); int mv88e6352_serdes_get_regs_len(struct mv88e6xxx_chip *chip, int port); void mv88e6352_serdes_get_regs(struct mv88e6xxx_chip *chip, int port, void *_p); -- 2.43.0