aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/stmmac/stmmac_ethtool.c
diff options
context:
space:
mode:
authorGiuseppe CAVALLARO <peppe.cavallaro@st.com>2010-08-23 16:40:42 -0400
committerDavid S. Miller <davem@davemloft.net>2010-08-25 19:30:51 -0400
commitad01b7d480a4a135f974afd5c617c417e0b0542f (patch)
treebd69865fb4bb323e697d46c8b0365ec1774a9696 /drivers/net/stmmac/stmmac_ethtool.c
parentac75791aa943c7953521cb4fa7728bf51f9abd2d (diff)
stmmac: make ioaddr 'void __iomem *' rather than unsigned long
This avoids unnecessary casting and adds the ioaddr in the private structure. This patch also removes many warning when compile the driver. Signed-off-by: Giuseppe Cavallaro <peppe.cavallaro@st.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/stmmac/stmmac_ethtool.c')
-rw-r--r--drivers/net/stmmac/stmmac_ethtool.c21
1 files changed, 9 insertions, 12 deletions
diff --git a/drivers/net/stmmac/stmmac_ethtool.c b/drivers/net/stmmac/stmmac_ethtool.c
index f080509923f0..63b68e61afce 100644
--- a/drivers/net/stmmac/stmmac_ethtool.c
+++ b/drivers/net/stmmac/stmmac_ethtool.c
@@ -177,21 +177,21 @@ void stmmac_ethtool_gregs(struct net_device *dev,
177 if (!priv->is_gmac) { 177 if (!priv->is_gmac) {
178 /* MAC registers */ 178 /* MAC registers */
179 for (i = 0; i < 12; i++) 179 for (i = 0; i < 12; i++)
180 reg_space[i] = readl(dev->base_addr + (i * 4)); 180 reg_space[i] = readl(priv->ioaddr + (i * 4));
181 /* DMA registers */ 181 /* DMA registers */
182 for (i = 0; i < 9; i++) 182 for (i = 0; i < 9; i++)
183 reg_space[i + 12] = 183 reg_space[i + 12] =
184 readl(dev->base_addr + (DMA_BUS_MODE + (i * 4))); 184 readl(priv->ioaddr + (DMA_BUS_MODE + (i * 4)));
185 reg_space[22] = readl(dev->base_addr + DMA_CUR_TX_BUF_ADDR); 185 reg_space[22] = readl(priv->ioaddr + DMA_CUR_TX_BUF_ADDR);
186 reg_space[23] = readl(dev->base_addr + DMA_CUR_RX_BUF_ADDR); 186 reg_space[23] = readl(priv->ioaddr + DMA_CUR_RX_BUF_ADDR);
187 } else { 187 } else {
188 /* MAC registers */ 188 /* MAC registers */
189 for (i = 0; i < 55; i++) 189 for (i = 0; i < 55; i++)
190 reg_space[i] = readl(dev->base_addr + (i * 4)); 190 reg_space[i] = readl(priv->ioaddr + (i * 4));
191 /* DMA registers */ 191 /* DMA registers */
192 for (i = 0; i < 22; i++) 192 for (i = 0; i < 22; i++)
193 reg_space[i + 55] = 193 reg_space[i + 55] =
194 readl(dev->base_addr + (DMA_BUS_MODE + (i * 4))); 194 readl(priv->ioaddr + (DMA_BUS_MODE + (i * 4)));
195 } 195 }
196} 196}
197 197
@@ -263,11 +263,9 @@ stmmac_set_pauseparam(struct net_device *netdev,
263 cmd.phy_address = phy->addr; 263 cmd.phy_address = phy->addr;
264 ret = phy_ethtool_sset(phy, &cmd); 264 ret = phy_ethtool_sset(phy, &cmd);
265 } 265 }
266 } else { 266 } else
267 unsigned long ioaddr = netdev->base_addr; 267 priv->hw->mac->flow_ctrl(priv->ioaddr, phy->duplex,
268 priv->hw->mac->flow_ctrl(ioaddr, phy->duplex,
269 priv->flow_ctrl, priv->pause); 268 priv->flow_ctrl, priv->pause);
270 }
271 spin_unlock(&priv->lock); 269 spin_unlock(&priv->lock);
272 return ret; 270 return ret;
273} 271}
@@ -276,12 +274,11 @@ static void stmmac_get_ethtool_stats(struct net_device *dev,
276 struct ethtool_stats *dummy, u64 *data) 274 struct ethtool_stats *dummy, u64 *data)
277{ 275{
278 struct stmmac_priv *priv = netdev_priv(dev); 276 struct stmmac_priv *priv = netdev_priv(dev);
279 unsigned long ioaddr = dev->base_addr;
280 int i; 277 int i;
281 278
282 /* Update HW stats if supported */ 279 /* Update HW stats if supported */
283 priv->hw->dma->dma_diagnostic_fr(&dev->stats, (void *) &priv->xstats, 280 priv->hw->dma->dma_diagnostic_fr(&dev->stats, (void *) &priv->xstats,
284 ioaddr); 281 priv->ioaddr);
285 282
286 for (i = 0; i < STMMAC_STATS_LEN; i++) { 283 for (i = 0; i < STMMAC_STATS_LEN; i++) {
287 char *p = (char *)priv + stmmac_gstrings_stats[i].stat_offset; 284 char *p = (char *)priv + stmmac_gstrings_stats[i].stat_offset;