lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Date:	Sun, 13 Mar 2016 15:50:16 +0000
From:	Ben Hutchings <ben@...adent.org.uk>
To:	Andrew Lunn <andrew@...n.ch>
Cc:	Florian Fainelli <f.fainelli@...il.com>,
	netdev <netdev@...r.kernel.org>
Subject: Re: [PATCH 2/2] ethtool: Add PHY statistics support

On Wed, 2015-12-23 at 12:58 +0100, Andrew Lunn wrote:
> This adds support for printing statistics from the network devices PHY.

Sorry it's taken me so long to respond to this.  There are a few issues
with it but I'll apply it anyway then fix them up.

> Signed-off-by: Andrew Lunn <andrew@...n.ch>
> ---
>  ethtool.8.in |  6 ++++++
>  ethtool.c    | 60 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
>  2 files changed, 66 insertions(+)
> 
> diff --git a/ethtool.8.in b/ethtool.8.in
> index eeffa70..2316556 100644
> --- a/ethtool.8.in
> +++ b/ethtool.8.in
> @@ -220,6 +220,9 @@ ethtool \- query or control network driver and hardware settings
>  .B ethtool \-S|\-\-statistics
>  .I devname
>  .HP
> +.B ethtool \-I|\-\-phy-statistics
> +.I devname
> +.HP

-I isn't a useful mnemonic, so I will drop the short option altogether.

>  .B ethtool \-t|\-\-test
>  .I devname
>  .RI [\*(SD]
> @@ -492,6 +495,9 @@ auto-negotiation is enabled.
>  Queries the specified network device for NIC- and driver-specific
>  statistics.
>  .TP
> +.B \-I \-\-phy\-statistics
> +Queries the specified network device for PHY specific statistics.
> +.TP
>  .B \-t \-\-test
>  Executes adapter selftest on the specified network device. Possible test modes are:
>  .TP
> diff --git a/ethtool.c b/ethtool.c
> index 92c40b8..480c14c 100644
> --- a/ethtool.c
> +++ b/ethtool.c
> @@ -2995,6 +2995,64 @@ static int do_gstats(struct cmd_context *ctx)
>  	return 0;
>  }
>  
> +static int do_gphystats(struct cmd_context *ctx)
> +{
> +	struct ethtool_gstrings *strings;
> +	struct ethtool_stats *stats;
> +	unsigned int n_stats, sz_stats, i;
> +	int err;
> +
> +	if (ctx->argc != 0)
> +		exit_bad_args();
> +
> +	strings = get_stringset(ctx, ETH_SS_PHY_STATS,
> +				offsetof(struct ethtool_drvinfo, n_stats),
> +				0);
> +	if (!strings) {
> +		perror("Cannot get stats strings information");
> +		return 96;
> +	}
> +

> +	n_stats = strings->len;
> +	if (n_stats < 1) {
> +		fprintf(stderr, "no stats available\n");
> +		free(strings);
> +		return 94;
> +	}
> +
> +	sz_stats = n_stats * sizeof(u64);
> +
> +	stats = calloc(1, sz_stats + sizeof(struct ethtool_stats));
> +	if (!stats) {
> +		fprintf(stderr, "no memory available\n");
> +		free(strings);
> +		return 95;
> +	}
> +
> +	stats->cmd = ETHTOOL_GPHYSTATS;
> +	stats->n_stats = n_stats;
> +	err = send_ioctl(ctx, stats);
> +	if (err < 0) {
> +		perror("Cannot get stats information");
> +		free(strings);
> +		free(stats);
> +		return 97;
> +	}
> +
> +	/* todo - pretty-print the strings per-driver */
> +	fprintf(stdout, "PHY statistics:\n");
> +	for (i = 0; i < n_stats; i++) {
> +		fprintf(stdout, "     %.*s: %llu\n",
> +			ETH_GSTRING_LEN,
> +			&strings->data[i * ETH_GSTRING_LEN],
> +			stats->data[i]);
> +	}
> +	free(strings);
> +	free(stats);
> +
> +	return 0;
> +}

This is basically a copy-paste of do_gstats() so they should be merged
into one function.

Ben.

>  static int do_srxntuple(struct cmd_context *ctx,
>  			struct ethtool_rx_flow_spec *rx_rule_fs);
>  
> @@ -4078,6 +4136,8 @@ static const struct option {
>  	{ "-t|--test", 1, do_test, "Execute adapter self test",
>  	  "               [ online | offline | external_lb ]\n" },
>  	{ "-S|--statistics", 1, do_gstats, "Show adapter statistics" },
> +	{ "-I|--phy-statistics", 1, do_gphystats,
> +	  "Show phy statistics" },
>  	{ "-n|-u|--show-nfc|--show-ntuple", 1, do_grxclass,
>  	  "Show Rx network flow classification options or rules",
>  	  "		[ rx-flow-hash tcp4|udp4|ah4|esp4|sctp4|"
-- 
Ben Hutchings
If at first you don't succeed, you're doing about average.
Download attachment "signature.asc" of type "application/pgp-signature" (820 bytes)

Powered by blists - more mailing lists