From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.3 required=3.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,SPF_HELO_NONE, SPF_PASS,USER_AGENT_SANE_1 autolearn=no autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 97016C433E0 for ; Tue, 26 May 2020 15:45:28 +0000 (UTC) Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id 5D51B20663 for ; Tue, 26 May 2020 15:45:28 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (2048-bit key) header.d=lists.infradead.org header.i=@lists.infradead.org header.b="KV20nZvV"; dkim=fail reason="signature verification failed" (1024-bit key) header.d=redhat.com header.i=@redhat.com header.b="MuDE1EeN" DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 5D51B20663 Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=redhat.com Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=linux-arm-kernel-bounces+infradead-linux-arm-kernel=archiver.kernel.org@lists.infradead.org DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20170209; h=Sender:Content-Type: Content-Transfer-Encoding:Cc:List-Subscribe:List-Help:List-Post:List-Archive: List-Unsubscribe:List-Id:In-Reply-To:MIME-Version:Date:Message-ID:From: References:To:Subject:Reply-To:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=VVBZt6TRht7LSMYkC2f1DfHrPHLYwwupC1I+VNUUuqs=; b=KV20nZvVpC278VyjM+z8ZWVFI H+0oejfZIcw8tfR8pCFxWJqzGl42PJtubBHYz1yuoSnOwQn6Ut1djp7GC7BCk647RlNLPm7yJs3lV lOyXzCv4dU3KidgU/xbwraBdnJXbSHNLFuSKTqIvRK0NFosYxX/FOJXkQYh+QbvxvqdkBjwxeku/Q kCNpmRJt89DbfO7Q8OIZG+j2hSqhWGS6UhVjcM1jtqtjp2AWxEoLtERT3KaX96xLivDriPUejJh0F /6MzLFojLBIj23KVW3/8hTelIoUe2qQCgN/IBRT5VRx0vMsGsRmcr20lSlth8QqN2aEIkoGcLWv6S 45Hlkwbfw==; Received: from localhost ([127.0.0.1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.92.3 #3 (Red Hat Linux)) id 1jdblf-0002qm-9g; Tue, 26 May 2020 15:45:27 +0000 Received: from us-smtp-2.mimecast.com ([205.139.110.61] helo=us-smtp-delivery-1.mimecast.com) by bombadil.infradead.org with esmtps (Exim 4.92.3 #3 (Red Hat Linux)) id 1jdblb-0002pq-UF for linux-arm-kernel@lists.infradead.org; Tue, 26 May 2020 15:45:25 +0000 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1590507922; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=Dt6LQHnd8XQKjoczzuKu5+J73yx/PTFTJmXrE029Qj0=; b=MuDE1EeNGCQ7ZtyasjHIeRquVoyGlw4ms/cF48n+wazvpvZJXtfMaHWohfbEpb6eu/b5pd cagcXwYz82p5Nr22SwvYHKapCY9bDujsdyxeL5jbNE0kD6wB2awofKGhTvYwW4Qc8IF3qm sR+IEuKfj/j1E+CuQh5LmGbRLqBM3+E= Received: from mail-wm1-f72.google.com (mail-wm1-f72.google.com [209.85.128.72]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-110-wougYa4XPJORVXxG_DgfRA-1; Tue, 26 May 2020 11:45:21 -0400 X-MC-Unique: wougYa4XPJORVXxG_DgfRA-1 Received: by mail-wm1-f72.google.com with SMTP id b63so145860wme.1 for ; Tue, 26 May 2020 08:45:20 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=Dt6LQHnd8XQKjoczzuKu5+J73yx/PTFTJmXrE029Qj0=; b=nQ4pFDa1+TddvvkrB2agRQsF6ZVd5g/QDGWbY+9v01ybhdgWqwu58dHSRFVxbFhryC Tsc9x75DuN8pmLkLrS8deA4d0VoB3SnH0H75eU5alb4auM49hgI0xS6RNskBrD947WDR blnnlZc8aRwsvd5euuO52yN2OC9iVq1ltQpzU5GjkJ472NClsNygHmQS2O7qJAOF+zWw a8eldPMsbFnt92fbHihTSNs4Chquol2GuWlpZML61wG08guyJI+Ipc8oj9lDdCt24Ty/ LcOLBzYhH1cJabbAohE0IVHcUXHeQeuetmMiNYklX3usxVI14NU4kES31/YIqXrYErMu 591A== X-Gm-Message-State: AOAM533DVOnBW3cMsyjsKJpQigJ1xr58kWchVD4ojMAjylRZOyV/Stbc fyJdj7Gke2unOjAyjFl5SSk5sEssN3a9HHQZOQizSvW9yWNTc2FCWoY+LnR/PFZHvXpXTK3KhNi 26Sd72TqZdimt763Tw9KF4zYGfTo9UcMjO9M= X-Received: by 2002:a05:6000:1202:: with SMTP id e2mr2590858wrx.231.1590507919724; Tue, 26 May 2020 08:45:19 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw5If1uNgTKWEisUAJowYTPwcuzMOOow4nahat1ESbDjPkHGjhZwTTbQrIPi02UQ5LtAAq4hw== X-Received: by 2002:a05:6000:1202:: with SMTP id e2mr2590848wrx.231.1590507919516; Tue, 26 May 2020 08:45:19 -0700 (PDT) Received: from localhost.localdomain ([194.230.155.118]) by smtp.gmail.com with ESMTPSA id u10sm32544wmc.31.2020.05.26.08.45.17 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Tue, 26 May 2020 08:45:18 -0700 (PDT) Subject: Re: [PATCH v3 7/7] [not for merge] netstats: example use of stats_fs API To: Andrew Lunn References: <20200526110318.69006-1-eesposit@redhat.com> <20200526110318.69006-8-eesposit@redhat.com> <20200526141605.GJ768009@lunn.ch> From: Emanuele Giuseppe Esposito Message-ID: <99217496-929f-ed3b-8e9e-bbd26d06e234@redhat.com> Date: Tue, 26 May 2020 17:45:17 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.8.0 MIME-Version: 1.0 In-Reply-To: <20200526141605.GJ768009@lunn.ch> Content-Language: en-US X-Mimecast-Spam-Score: 0 X-Mimecast-Originator: redhat.com X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20200526_084524_063326_2CCDC7CC X-CRM114-Status: GOOD ( 18.57 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: linux-s390@vger.kernel.org, kvm@vger.kernel.org, linux-doc@vger.kernel.org, netdev@vger.kernel.org, Emanuele Giuseppe Esposito , linux-kernel@vger.kernel.org, kvm-ppc@vger.kernel.org, Jonathan Adams , Christian Borntraeger , Alexander Viro , David Rientjes , linux-fsdevel@vger.kernel.org, Paolo Bonzini , linux-mips@vger.kernel.org, linuxppc-dev@lists.ozlabs.org, linux-arm-kernel@lists.infradead.org, Jim Mattson Content-Transfer-Encoding: 7bit Content-Type: text/plain; charset="us-ascii"; Format="flowed" Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+infradead-linux-arm-kernel=archiver.kernel.org@lists.infradead.org Hi Andrew > How do you atomically get and display a group of statistics? > > If you look at how the netlink socket works, you will see code like: > > do { > start = u64_stats_fetch_begin_irq(&cpu_stats->syncp); > rx_packets = cpu_stats->rx_packets; > rx_bytes = cpu_stats->rx_bytes; > .... > } while (u64_stats_fetch_retry_irq(&cpu_stats->syncp, start)); > > It will ensure that rx_packets and rx_bytes are consistent with each > other. If the value of the sequence counter changes while inside the > loop, the loop so repeated until it does not change. > > In general, hardware counters in NICs are the same. You tell it to > take a snapshot of the statistics counters, and then read them all > back, to give a consistent view across all the statistics. > > I've not looked at this new code in detail, but it looks like you have > one file per statistic, and assume each statistic is independent of > every other statistic. This independence can limit how you use the > values, particularly when debugging. The netlink interface we use does > not have this limitation. You're right, statistics are treated independently so what you describe is currently not supported. In KVM the utilization is more qualitative, so there isn't such problem. But as long as the interface is based on file access, the possibility of snapshotting might not be useful; however, it could still be considered to be added later together with the binary access. Jonathan, how is your metricfs handling this case? Thank you, Emanuele _______________________________________________ linux-arm-kernel mailing list linux-arm-kernel@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-arm-kernel