From: Sascha Hauer <s.hauer@pengutronix.de>
To: barebox@lists.infradead.org
Subject: [PATCH 2/2] miitool: Add support for examing mdio bus
Date: Fri, 8 Feb 2013 10:24:17 +0100 [thread overview]
Message-ID: <1360315457-30382-3-git-send-email-s.hauer@pengutronix.de> (raw)
In-Reply-To: <1360315457-30382-1-git-send-email-s.hauer@pengutronix.de>
Current miitool usage is limited to a single phy on a mdio bus.
For debugging purposes it is useful to be able to examine a mdio bus
instead of a single phy only.
This adds support for this to the miitool command.
Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
---
commands/miitool.c | 94 +++++++++++++++++++++++++++++++++++++++++-----------
1 file changed, 75 insertions(+), 19 deletions(-)
diff --git a/commands/miitool.c b/commands/miitool.c
index 3a9ac45..b9e2333 100644
--- a/commands/miitool.c
+++ b/commands/miitool.c
@@ -37,23 +37,36 @@
#include <linux/stat.h>
#include <xfuncs.h>
#include <linux/mii.h>
+#include <linux/phy.h>
-static u16 mdio_read(int fd, int offset)
+static int phy_fd;
+
+static u16 mdio_file_read(int offset)
{
int ret;
u16 buf;
- ret = lseek(fd, offset << 1, SEEK_SET);
+ ret = lseek(phy_fd, offset << 1, SEEK_SET);
if (ret < 0)
return 0;
- ret = read(fd, &buf, sizeof(u16));
+ ret = read(phy_fd, &buf, sizeof(u16));
if (ret < 0)
return 0;
return buf;
}
+static struct mii_bus *mii_bus;
+static int mii_address;
+
+static u16 mdio_bus_read(int offset)
+{
+ return mdiobus_read(mii_bus, mii_address, offset);
+}
+
+static u16 (*mdio_read)(int offset);
+
/* Table of known MII's */
static const struct {
u_short id1, id2;
@@ -101,7 +114,7 @@ static char *media_list(int mask, int best)
return buf;
}
-static int show_basic_mii(int fd, int verbose)
+static int show_basic_mii(int verbose)
{
char buf[100];
int i, mii_val[32];
@@ -109,9 +122,9 @@ static int show_basic_mii(int fd, int verbose)
/* Some bits in the BMSR are latched, but we can't rely on being
the only reader, so only the current values are meaningful */
- mdio_read(fd, MII_BMSR);
+ mdio_read(MII_BMSR);
for (i = 0; i < ((verbose > 1) ? 32 : 8); i++)
- mii_val[i] = mdio_read(fd, i);
+ mii_val[i] = mdio_read(i);
if (mii_val[MII_BMCR] == 0xffff) {
fprintf(stderr, " No MII transceiver present!.\n");
@@ -213,18 +226,25 @@ static int show_basic_mii(int fd, int verbose)
static int do_miitool(int argc, char *argv[])
{
- char *filename;
+ char *filename = NULL;
+ char *devname = NULL;
int opt;
int argc_min;
- int fd;
int verbose;
+ int address = -1;
verbose = 0;
- while ((opt = getopt(argc, argv, "v")) > 0) {
+ while ((opt = getopt(argc, argv, "vd:a:")) > 0) {
switch (opt) {
case 'v':
verbose++;
break;
+ case 'd':
+ devname = optarg;
+ break;
+ case 'a':
+ address = simple_strtoul(optarg, NULL, 0);
+ break;
default:
return COMMAND_ERROR_USAGE;
}
@@ -232,27 +252,63 @@ static int do_miitool(int argc, char *argv[])
argc_min = optind + 1;
- if (argc < argc_min)
+ if (argc >= argc_min)
+ filename = argv[optind];
+
+ if (filename && devname) {
+ printf("both filename and devicename given\n");
return COMMAND_ERROR_USAGE;
+ }
- filename = argv[optind];
+ if (!filename && !devname) {
+ printf("no filename or devicename given\n");
+ return COMMAND_ERROR_USAGE;
+ }
+
+ if (filename) {
+ phy_fd = open(filename, O_RDONLY);
+ if (phy_fd < 0) {
+ printf("unable to read %s\n", filename);
+ return COMMAND_ERROR;
+ }
+
+ mdio_read = mdio_file_read;
+
+ show_basic_mii(verbose);
+ } else {
+ mii_bus = mdiobus_find(devname);
+
+ if (!mii_bus)
+ return -ENODEV;
- fd = open(filename, O_RDONLY);
- if (fd < 0) {
- printf("unable to read %s\n", filename);
- return COMMAND_ERROR;
+ mdio_read = mdio_bus_read;
+ if (address < 0) {
+ for (mii_address = 0; mii_address < PHY_MAX_ADDR; mii_address++) {
+ printf("`---- phyadr %d:\n",
+ mii_address);
+ show_basic_mii(verbose);
+ }
+ } else {
+ mii_address = address;
+ show_basic_mii(verbose);
+ }
}
- show_basic_mii(fd, verbose);
- close(fd);
+ if (filename)
+ close(phy_fd);
return COMMAND_SUCCESS;
}
BAREBOX_CMD_HELP_START(miitool)
-BAREBOX_CMD_HELP_USAGE("miitool [[[-v] -v] -v] <phy>\n")
-BAREBOX_CMD_HELP_SHORT("view status for MII <phy>.\n")
+BAREBOX_CMD_HELP_USAGE("miitool [OPTIONS] [phy]\n")
+BAREBOX_CMD_HELP_SHORT("view status mii phy device status\n")
+BAREBOX_CMD_HELP_SHORT("Use [phy] to view a phy connected to an ethernet device\n")
+BAREBOX_CMD_HELP_SHORT("or -d <devname> [-a <phyadr>] to examine a mii bus\n")
+BAREBOX_CMD_HELP_OPT("-v", "\tverbose, may be given multiple times\n")
+BAREBOX_CMD_HELP_OPT("-d <devname>", "work on miibus <devname>\n")
+BAREBOX_CMD_HELP_OPT("-a <phyadr>", "Use phy address <phyadr>, used together with -d\n")
BAREBOX_CMD_HELP_END
/**
--
1.7.10.4
_______________________________________________
barebox mailing list
barebox@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/barebox
next prev parent reply other threads:[~2013-02-08 9:24 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-02-08 9:24 [PATCH v2] add mdio bus support to miitool Sascha Hauer
2013-02-08 9:24 ` [PATCH 1/2] net phy: Add mdio buses to mdio_bus_type Sascha Hauer
2013-02-08 9:24 ` Sascha Hauer [this message]
2013-02-08 11:02 ` [PATCH 2/2] miitool: Add support for examing mdio bus Alexander Aring
2013-02-11 11:40 ` Sascha Hauer
2013-02-11 23:13 ` Alexander Aring
2013-02-12 7:35 ` Sascha Hauer
-- strict thread matches above, loose matches on Subject: below --
2013-02-07 11:09 [PATCH 1/2] net phy: Add support for finding a mdio bus by its name Sascha Hauer
2013-02-07 11:09 ` [PATCH 2/2] miitool: Add support for examing mdio bus Sascha Hauer
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1360315457-30382-3-git-send-email-s.hauer@pengutronix.de \
--to=s.hauer@pengutronix.de \
--cc=barebox@lists.infradead.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox