Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp1368702ybl; Wed, 18 Dec 2019 17:37:52 -0800 (PST) X-Google-Smtp-Source: APXvYqwzLwi7BwCUxSMwJQ9z5fcp9c8NQxY51vsTVP/PYsa5GxHvbCfdEjXbKtEcWhTegSsVCiX6 X-Received: by 2002:a9d:ed5:: with SMTP id 79mr6027182otj.72.1576719472011; Wed, 18 Dec 2019 17:37:52 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1576719471; cv=none; d=google.com; s=arc-20160816; b=DHdC2qpCvD0plS4g3RKH07sBrTaHvb3LZZ2+MXdG+1sB3y8NWnEjjSjVN1jE+7lK3w 9MVsvV7STKfvaU0waABO9E+1EmRYzNKDGYLXilyGrdONf3MEn8JIp243Kci7XPHxCxBq q6DQ3blEj0hJ1Mq95Lihfj/YDyXZZX6gwvYeMX4L9q4JfDYIau54VMHfGgLv6N76eTax pTVEoTjczvdspCWvdME59hwAFztiZeoIvGsQK31VG8vdUhCw9lLUgroH82e8r2td0EAy 3pSxgYPnSObtl4wjs6zhuc9fNoUYqQuWfOdI0UQtcrW62zror3JEqzEhiJ9miYSDI94e 7Oxg== 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 :message-id:date:subject:cc:to:from; bh=moprH98OQs3MHHx35tfkSvp81WjukaILJZmJ8ACuOcI=; b=cqWNfChW3eiQ4P9OGx/mAJiWcKIt0Ml5VJwghFJl2rsHWnICJfG1xxi78ZFNoTgPeo oVKgxpymB0SgZgIQGnxvFdnkMg7AaWfRDxNXLbOLgVvXDIA8UNRTY7fbKnOlV89HEnBI uBMcFWEqkAdr2zclqGHjHz1GHxKwlzkU304FAEWbPZK3V3P5+xKNTCqw+omUi2cVcK+N A1c2qkWhj7h5YiDEpszq5Zq2oOcrGd8XyLmQL+Em1Q1HVPijdCo+vRwVlWY2BE6R230B OgoJLHPCLfwghnUN6+2uHPkIOjw+Fs2NPT2g3DG3qGDnfCb43+HgHctP+tDvXOeCkgoK m8nw== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id l84si2240174oig.5.2019.12.18.17.37.41; Wed, 18 Dec 2019 17:37:51 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726791AbfLSBhB (ORCPT + 99 others); Wed, 18 Dec 2019 20:37:01 -0500 Received: from szxga07-in.huawei.com ([45.249.212.35]:58530 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726463AbfLSBhB (ORCPT ); Wed, 18 Dec 2019 20:37:01 -0500 Received: from DGGEMS414-HUB.china.huawei.com (unknown [172.30.72.59]) by Forcepoint Email with ESMTP id 8CAE8E6E34F961F4045C; Thu, 19 Dec 2019 09:36:58 +0800 (CST) Received: from localhost.localdomain.localdomain (10.175.113.25) by DGGEMS414-HUB.china.huawei.com (10.3.19.214) with Microsoft SMTP Server id 14.3.439.0; Thu, 19 Dec 2019 09:36:48 +0800 From: Mao Wenan To: , , , , , , , CC: , , Subject: [PATCH net] af_packet: refactoring code for prb_calc_retire_blk_tmo Date: Thu, 19 Dec 2019 09:33:44 +0800 Message-ID: <20191219013344.34603-1-maowenan@huawei.com> X-Mailer: git-send-email 2.20.1 MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [10.175.113.25] X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org If __ethtool_get_link_ksettings() is failed and with non-zero value, prb_calc_retire_blk_tmo() should return DEFAULT_PRB_RETIRE_TOV firstly. Refactoring code and make it more readable. Fixes: b43d1f9f7067 ("af_packet: set defaule value for tmo") Signed-off-by: Mao Wenan --- net/packet/af_packet.c | 26 +++++++++++--------------- 1 file changed, 11 insertions(+), 15 deletions(-) diff --git a/net/packet/af_packet.c b/net/packet/af_packet.c index 118cd66..843ebf8 100644 --- a/net/packet/af_packet.c +++ b/net/packet/af_packet.c @@ -520,7 +520,7 @@ static int prb_calc_retire_blk_tmo(struct packet_sock *po, int blk_size_in_bytes) { struct net_device *dev; - unsigned int mbits = 0, msec = 0, div = 0, tmo = 0; + unsigned int mbits = 0, msec = 1, div = 0, tmo = 0; struct ethtool_link_ksettings ecmd; int err; @@ -532,21 +532,17 @@ static int prb_calc_retire_blk_tmo(struct packet_sock *po, } err = __ethtool_get_link_ksettings(dev, &ecmd); rtnl_unlock(); - if (!err) { - /* - * If the link speed is so slow you don't really - * need to worry about perf anyways - */ - if (ecmd.base.speed < SPEED_1000 || - ecmd.base.speed == SPEED_UNKNOWN) { - return DEFAULT_PRB_RETIRE_TOV; - } else { - msec = 1; - div = ecmd.base.speed / 1000; - } - } else + if (err) + return DEFAULT_PRB_RETIRE_TOV; + + /* If the link speed is so slow you don't really + * need to worry about perf anyways + */ + if (ecmd.base.speed < SPEED_1000 || + ecmd.base.speed == SPEED_UNKNOWN) return DEFAULT_PRB_RETIRE_TOV; + div = ecmd.base.speed / 1000; mbits = (blk_size_in_bytes * 8) / (1024 * 1024); if (div) @@ -555,7 +551,7 @@ static int prb_calc_retire_blk_tmo(struct packet_sock *po, tmo = mbits * msec; if (div) - return tmo+1; + return tmo + 1; return tmo; } -- 2.7.4