Received: by 2002:a25:f815:0:0:0:0:0 with SMTP id u21csp1037137ybd; Wed, 26 Jun 2019 10:04:41 -0700 (PDT) X-Google-Smtp-Source: APXvYqxw8q//MvcHyquGuTgzIXQqwol8V/ErbS/rN1YXg6kSOFGaP4noxcJ6orjmotWzNcSSa4wS X-Received: by 2002:a63:d218:: with SMTP id a24mr3995375pgg.419.1561568681004; Wed, 26 Jun 2019 10:04:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1561568680; cv=none; d=google.com; s=arc-20160816; b=HQsC3QH/8j0A5vqTvg1l0Sus5FVWOQsrgeqmxtiyChGvXMNDo8mmVRWqtF24rgp8zS LzR+8haM8Kgi7xU4F4EV6e7v03blXHvkOYG3xWeII5htyw+S5IvWLqvyxGcZkxUSIokS uRTzp9djhY0NrCkq5sc6PsfzImdZGh//0l4L3mIqhkKrwaPRNDxg56q6wonNLGlQsSTN 6/S6b3Y1nrnS8K7XAE4V90t40+1mbYiBb3GBxk1mIJGQ3zgykaoEvhJRCcClMMaiVIA7 aTUpjCRXcWWfjrtNi+BsKTm7ciixyPArjeGRVrvQHUQpU6o6YPlacOpaYtACD7mBJZHW f+jA== 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=Hh+xC2bQ0ULuOIK9+r0Db8kvtfie3Ktg7hMZ+kMCfB0=; b=ijs1+MEw76QDwlzS9u4c+nbWXBUWq3AdRPNcoPUPmMMZ7n25Ejye7fgbyw2kQXC1CU 5YIVgWsFCLiK23qFTHTiK/3EKnmr90Kg4xFvwkEK9NP2l0LJWXuZkVIAZLeR4lMiFlhy 11+VGJm0cyKZ6L+vId29XzWRHtcWKwxBsyH+3zLtBiGTDtvKLuZA/eaG253xuZW7ECYS Aj4CILxaE/d1EMZNao/YA08b+XG37FVsYEkykt2KHxyBGd0eEb/De3sycjq0paE0anEN A1Vn0NOe7yOWIZRTiPRr4kXb7w+bcbzMZFIJMiPXG7kjNkpwAPgpg4AB4uitRkeOsEra vqDg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-nfs-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-nfs-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id y16si15805767pfe.129.2019.06.26.10.04.17; Wed, 26 Jun 2019 10:04:40 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-nfs-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-nfs-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-nfs-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726006AbfFZRDC (ORCPT + 99 others); Wed, 26 Jun 2019 13:03:02 -0400 Received: from mx1.redhat.com ([209.132.183.28]:33312 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726179AbfFZRDB (ORCPT ); Wed, 26 Jun 2019 13:03:01 -0400 Received: from smtp.corp.redhat.com (int-mx01.intmail.prod.int.phx2.redhat.com [10.5.11.11]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 4091D308792E; Wed, 26 Jun 2019 17:03:01 +0000 (UTC) Received: from f29-node1.dwysocha.net (dhcp145-42.rdu.redhat.com [10.13.145.42]) by smtp.corp.redhat.com (Postfix) with ESMTP id EE64B600CC; Wed, 26 Jun 2019 17:02:59 +0000 (UTC) From: Dave Wysochanski To: chuck.lever@oracle.com, SteveD@RedHat.com Cc: linux-nfs@vger.kernel.org Subject: [PATCH] mountstats: Fix nfsstat command to handle RPC iostats version >= 1.1 Date: Wed, 26 Jun 2019 13:02:58 -0400 Message-Id: <20190626170259.8347-1-dwysocha@redhat.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Scanned-By: MIMEDefang 2.79 on 10.5.11.11 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.45]); Wed, 26 Jun 2019 17:03:01 +0000 (UTC) Sender: linux-nfs-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-nfs@vger.kernel.org Later kernels with RPC iostats version >= 1.1 have an additional errors count for each op. Lengthen the array of values created inside DeviceData and then in __parse_rpc_line just zero this value out for prior kernels where this count is not present. The count is not used for nfsstat, but this keeps DeviceData consistent with the new count as well as proper functioning of accumulate_iostats. Before this patch, nfsstat will backtrace on a kernel with RPC iostats version >= 1.1 due to the fixed array inside DeviceData. This patch fixes this backtrace and also allows nfsstat to work with these new kernels. Signed-off-by: Dave Wysochanski --- tools/mountstats/mountstats.py | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/tools/mountstats/mountstats.py b/tools/mountstats/mountstats.py index c5e8f506..6ac83ccb 100755 --- a/tools/mountstats/mountstats.py +++ b/tools/mountstats/mountstats.py @@ -308,6 +308,8 @@ class DeviceData: op = words[0][:-1] self.__rpc_data['ops'] += [op] self.__rpc_data[op] = [int(word) for word in words[1:]] + if len(self.__rpc_data[op]) < 9: + self.__rpc_data[op] += [0] def parse_stats(self, lines): """Turn a list of lines from a mount stat file into a @@ -582,7 +584,7 @@ class DeviceData: self.__nfs_data['fstype'] = 'nfs4' self.__rpc_data['ops'] = ops for op in ops: - self.__rpc_data[op] = [0 for i in range(8)] + self.__rpc_data[op] = [0 for i in range(9)] def accumulate_iostats(self, new_stats): """Accumulate counters from all RPC op buckets in new_stats. This is -- 2.20.1