]> git.sur5r.net Git - u-boot/commitdiff
miiphy: leverage current_mii cache more
authorMike Frysinger <vapier@gentoo.org>
Tue, 27 Jul 2010 22:35:10 +0000 (18:35 -0400)
committerBen Warren <biggerbadderben@gmail.com>
Mon, 9 Aug 2010 18:52:30 +0000 (11:52 -0700)
For code that uses miiphy_{read,write}, every call invokes a full look up
of the mii list.  There is already a "current_mii" cache that is used by
some code, but have the miiphy_{read,write} function use it as well.  This
does increase the code size slightly, but I think it's worth it.

Signed-off-by: Mike Frysinger <vapier@gentoo.org>
Signed-off-by: Ben Warren <biggerbadderben@gmail.com>
common/miiphyutil.c

index e055c08fbd6aef22e907693b00952dd6657674b7..9cf845f605dca3940c821976247b647847a91636 100644 (file)
@@ -162,6 +162,20 @@ const char *miiphy_get_current_dev(void)
        return NULL;
 }
 
+static struct mii_dev *miiphy_get_active_dev(const char *devname)
+{
+       /* If the current mii is the one we want, return it */
+       if (current_mii)
+               if (strcmp(current_mii->name, devname) == 0)
+                       return current_mii;
+
+       /* Otherwise, set the active one to the one we want */
+       if (miiphy_set_current_dev(devname))
+               return NULL;
+       else
+               return current_mii;
+}
+
 /*****************************************************************************
  *
  * Read to variable <value> from the PHY attached to device <devname>,
@@ -175,7 +189,7 @@ int miiphy_read(const char *devname, unsigned char addr, unsigned char reg,
 {
        struct mii_dev *dev;
 
-       dev = miiphy_get_dev_by_name(devname, 0);
+       dev = miiphy_get_active_dev(devname);
        if (dev)
                return dev->read(devname, addr, reg, value);
 
@@ -195,7 +209,7 @@ int miiphy_write(const char *devname, unsigned char addr, unsigned char reg,
 {
        struct mii_dev *dev;
 
-       dev = miiphy_get_dev_by_name(devname, 0);
+       dev = miiphy_get_active_dev(devname);
        if (dev)
                return dev->write(devname, addr, reg, value);