net: emaclite: use __raw_readl/writel instead of weird define

out_be32 and in_be32 are actually #defined to little endian
writel/readl in arch/microblaze.

Just use __raw_writel/readl instead. That is also what is used
in the Linux kernel driver for this IP block

Tested on MIPSfpga. Can tftp a kernel.

Signed-off-by: Zubair Lutfullah Kakakhel <Zubair.Kakakhel@imgtec.com>
Reviewed-by: Paul Burton <paul.burton@imgtec.com>
Acked-by: Joe Hershberger <joe.hershberger@ni.com>
This commit is contained in:
Zubair Lutfullah Kakakhel 2016-07-27 12:25:08 +01:00 committed by Daniel Schwierzeck
parent 39e020ef16
commit 611fe0bddb
1 changed files with 45 additions and 41 deletions

View File

@ -155,7 +155,7 @@ static int wait_for_bit(const char *func, u32 *reg, const u32 mask,
unsigned long start = get_timer(0); unsigned long start = get_timer(0);
while (1) { while (1) {
val = readl(reg); val = __raw_readl(reg);
if (!set) if (!set)
val = ~val; val = ~val;
@ -194,16 +194,17 @@ static u32 phyread(struct xemaclite *emaclite, u32 phyaddress, u32 registernum,
if (mdio_wait(regs)) if (mdio_wait(regs))
return 1; return 1;
u32 ctrl_reg = in_be32(&regs->mdioctrl); u32 ctrl_reg = __raw_readl(&regs->mdioctrl);
out_be32(&regs->mdioaddr, XEL_MDIOADDR_OP_MASK | __raw_writel(XEL_MDIOADDR_OP_MASK
((phyaddress << XEL_MDIOADDR_PHYADR_SHIFT) | registernum)); | ((phyaddress << XEL_MDIOADDR_PHYADR_SHIFT)
out_be32(&regs->mdioctrl, ctrl_reg | XEL_MDIOCTRL_MDIOSTS_MASK); | registernum), &regs->mdioaddr);
__raw_writel(ctrl_reg | XEL_MDIOCTRL_MDIOSTS_MASK, &regs->mdioctrl);
if (mdio_wait(regs)) if (mdio_wait(regs))
return 1; return 1;
/* Read data */ /* Read data */
*data = in_be32(&regs->mdiord); *data = __raw_readl(&regs->mdiord);
return 0; return 0;
} }
@ -221,11 +222,12 @@ static u32 phywrite(struct xemaclite *emaclite, u32 phyaddress, u32 registernum,
* Data register. Finally, set the Status bit in the MDIO Control * Data register. Finally, set the Status bit in the MDIO Control
* register to start a MDIO write transaction. * register to start a MDIO write transaction.
*/ */
u32 ctrl_reg = in_be32(&regs->mdioctrl); u32 ctrl_reg = __raw_readl(&regs->mdioctrl);
out_be32(&regs->mdioaddr, ~XEL_MDIOADDR_OP_MASK & __raw_writel(~XEL_MDIOADDR_OP_MASK
((phyaddress << XEL_MDIOADDR_PHYADR_SHIFT) | registernum)); & ((phyaddress << XEL_MDIOADDR_PHYADR_SHIFT)
out_be32(&regs->mdiowr, data); | registernum), &regs->mdioaddr);
out_be32(&regs->mdioctrl, ctrl_reg | XEL_MDIOCTRL_MDIOSTS_MASK); __raw_writel(data, &regs->mdiowr);
__raw_writel(ctrl_reg | XEL_MDIOCTRL_MDIOSTS_MASK, &regs->mdioctrl);
if (mdio_wait(regs)) if (mdio_wait(regs))
return 1; return 1;
@ -328,27 +330,27 @@ static int emaclite_start(struct udevice *dev)
* TX - TX_PING & TX_PONG initialization * TX - TX_PING & TX_PONG initialization
*/ */
/* Restart PING TX */ /* Restart PING TX */
out_be32(&regs->tx_ping_tsr, 0); __raw_writel(0, &regs->tx_ping_tsr);
/* Copy MAC address */ /* Copy MAC address */
xemaclite_alignedwrite(pdata->enetaddr, &regs->tx_ping, xemaclite_alignedwrite(pdata->enetaddr, &regs->tx_ping,
ENET_ADDR_LENGTH); ENET_ADDR_LENGTH);
/* Set the length */ /* Set the length */
out_be32(&regs->tx_ping_tplr, ENET_ADDR_LENGTH); __raw_writel(ENET_ADDR_LENGTH, &regs->tx_ping_tplr);
/* Update the MAC address in the EMAC Lite */ /* Update the MAC address in the EMAC Lite */
out_be32(&regs->tx_ping_tsr, XEL_TSR_PROG_MAC_ADDR); __raw_writel(XEL_TSR_PROG_MAC_ADDR, &regs->tx_ping_tsr);
/* Wait for EMAC Lite to finish with the MAC address update */ /* Wait for EMAC Lite to finish with the MAC address update */
while ((in_be32 (&regs->tx_ping_tsr) & while ((__raw_readl(&regs->tx_ping_tsr) &
XEL_TSR_PROG_MAC_ADDR) != 0) XEL_TSR_PROG_MAC_ADDR) != 0)
; ;
if (emaclite->txpp) { if (emaclite->txpp) {
/* The same operation with PONG TX */ /* The same operation with PONG TX */
out_be32(&regs->tx_pong_tsr, 0); __raw_writel(0, &regs->tx_pong_tsr);
xemaclite_alignedwrite(pdata->enetaddr, &regs->tx_pong, xemaclite_alignedwrite(pdata->enetaddr, &regs->tx_pong,
ENET_ADDR_LENGTH); ENET_ADDR_LENGTH);
out_be32(&regs->tx_pong_tplr, ENET_ADDR_LENGTH); __raw_writel(ENET_ADDR_LENGTH, &regs->tx_pong_tplr);
out_be32(&regs->tx_pong_tsr, XEL_TSR_PROG_MAC_ADDR); __raw_writel(XEL_TSR_PROG_MAC_ADDR, &regs->tx_pong_tsr);
while ((in_be32(&regs->tx_pong_tsr) & while ((__raw_readl(&regs->tx_pong_tsr) &
XEL_TSR_PROG_MAC_ADDR) != 0) XEL_TSR_PROG_MAC_ADDR) != 0)
; ;
} }
@ -357,13 +359,13 @@ static int emaclite_start(struct udevice *dev)
* RX - RX_PING & RX_PONG initialization * RX - RX_PING & RX_PONG initialization
*/ */
/* Write out the value to flush the RX buffer */ /* Write out the value to flush the RX buffer */
out_be32(&regs->rx_ping_rsr, XEL_RSR_RECV_IE_MASK); __raw_writel(XEL_RSR_RECV_IE_MASK, &regs->rx_ping_rsr);
if (emaclite->rxpp) if (emaclite->rxpp)
out_be32(&regs->rx_pong_rsr, XEL_RSR_RECV_IE_MASK); __raw_writel(XEL_RSR_RECV_IE_MASK, &regs->rx_pong_rsr);
out_be32(&regs->mdioctrl, XEL_MDIOCTRL_MDIOEN_MASK); __raw_writel(XEL_MDIOCTRL_MDIOEN_MASK, &regs->mdioctrl);
if (in_be32(&regs->mdioctrl) & XEL_MDIOCTRL_MDIOEN_MASK) if (__raw_readl(&regs->mdioctrl) & XEL_MDIOCTRL_MDIOEN_MASK)
if (!setup_phy(dev)) if (!setup_phy(dev))
return -1; return -1;
@ -380,9 +382,9 @@ static int xemaclite_txbufferavailable(struct xemaclite *emaclite)
* Read the other buffer register * Read the other buffer register
* and determine if the other buffer is available * and determine if the other buffer is available
*/ */
tmp = ~in_be32(&regs->tx_ping_tsr); tmp = ~__raw_readl(&regs->tx_ping_tsr);
if (emaclite->txpp) if (emaclite->txpp)
tmp |= ~in_be32(&regs->tx_pong_tsr); tmp |= ~__raw_readl(&regs->tx_pong_tsr);
return !(tmp & XEL_TSR_XMIT_BUSY_MASK); return !(tmp & XEL_TSR_XMIT_BUSY_MASK);
} }
@ -406,40 +408,42 @@ static int emaclite_send(struct udevice *dev, void *ptr, int len)
if (!maxtry) { if (!maxtry) {
printf("Error: Timeout waiting for ethernet TX buffer\n"); printf("Error: Timeout waiting for ethernet TX buffer\n");
/* Restart PING TX */ /* Restart PING TX */
out_be32(&regs->tx_ping_tsr, 0); __raw_writel(0, &regs->tx_ping_tsr);
if (emaclite->txpp) { if (emaclite->txpp) {
out_be32(&regs->tx_pong_tsr, 0); __raw_writel(0, &regs->tx_pong_tsr);
} }
return -1; return -1;
} }
/* Determine if the expected buffer address is empty */ /* Determine if the expected buffer address is empty */
reg = in_be32(&regs->tx_ping_tsr); reg = __raw_readl(&regs->tx_ping_tsr);
if ((reg & XEL_TSR_XMIT_BUSY_MASK) == 0) { if ((reg & XEL_TSR_XMIT_BUSY_MASK) == 0) {
debug("Send packet from tx_ping buffer\n"); debug("Send packet from tx_ping buffer\n");
/* Write the frame to the buffer */ /* Write the frame to the buffer */
xemaclite_alignedwrite(ptr, &regs->tx_ping, len); xemaclite_alignedwrite(ptr, &regs->tx_ping, len);
out_be32(&regs->tx_ping_tplr, len & __raw_writel(len
(XEL_TPLR_LENGTH_MASK_HI | XEL_TPLR_LENGTH_MASK_LO)); & (XEL_TPLR_LENGTH_MASK_HI | XEL_TPLR_LENGTH_MASK_LO),
reg = in_be32(&regs->tx_ping_tsr); &regs->tx_ping_tplr);
reg = __raw_readl(&regs->tx_ping_tsr);
reg |= XEL_TSR_XMIT_BUSY_MASK; reg |= XEL_TSR_XMIT_BUSY_MASK;
out_be32(&regs->tx_ping_tsr, reg); __raw_writel(reg, &regs->tx_ping_tsr);
return 0; return 0;
} }
if (emaclite->txpp) { if (emaclite->txpp) {
/* Determine if the expected buffer address is empty */ /* Determine if the expected buffer address is empty */
reg = in_be32(&regs->tx_pong_tsr); reg = __raw_readl(&regs->tx_pong_tsr);
if ((reg & XEL_TSR_XMIT_BUSY_MASK) == 0) { if ((reg & XEL_TSR_XMIT_BUSY_MASK) == 0) {
debug("Send packet from tx_pong buffer\n"); debug("Send packet from tx_pong buffer\n");
/* Write the frame to the buffer */ /* Write the frame to the buffer */
xemaclite_alignedwrite(ptr, &regs->tx_pong, len); xemaclite_alignedwrite(ptr, &regs->tx_pong, len);
out_be32(&regs->tx_pong_tplr, len & __raw_writel(len &
(XEL_TPLR_LENGTH_MASK_HI | (XEL_TPLR_LENGTH_MASK_HI |
XEL_TPLR_LENGTH_MASK_LO)); XEL_TPLR_LENGTH_MASK_LO),
reg = in_be32(&regs->tx_pong_tsr); &regs->tx_pong_tplr);
reg = __raw_readl(&regs->tx_pong_tsr);
reg |= XEL_TSR_XMIT_BUSY_MASK; reg |= XEL_TSR_XMIT_BUSY_MASK;
out_be32(&regs->tx_pong_tsr, reg); __raw_writel(reg, &regs->tx_pong_tsr);
return 0; return 0;
} }
} }
@ -459,7 +463,7 @@ static int emaclite_recv(struct udevice *dev, int flags, uchar **packetp)
try_again: try_again:
if (!emaclite->use_rx_pong_buffer_next) { if (!emaclite->use_rx_pong_buffer_next) {
reg = in_be32(&regs->rx_ping_rsr); reg = __raw_readl(&regs->rx_ping_rsr);
debug("Testing data at rx_ping\n"); debug("Testing data at rx_ping\n");
if ((reg & XEL_RSR_RECV_DONE_MASK) == XEL_RSR_RECV_DONE_MASK) { if ((reg & XEL_RSR_RECV_DONE_MASK) == XEL_RSR_RECV_DONE_MASK) {
debug("Data found in rx_ping buffer\n"); debug("Data found in rx_ping buffer\n");
@ -479,7 +483,7 @@ try_again:
goto try_again; goto try_again;
} }
} else { } else {
reg = in_be32(&regs->rx_pong_rsr); reg = __raw_readl(&regs->rx_pong_rsr);
debug("Testing data at rx_pong\n"); debug("Testing data at rx_pong\n");
if ((reg & XEL_RSR_RECV_DONE_MASK) == XEL_RSR_RECV_DONE_MASK) { if ((reg & XEL_RSR_RECV_DONE_MASK) == XEL_RSR_RECV_DONE_MASK) {
debug("Data found in rx_pong buffer\n"); debug("Data found in rx_pong buffer\n");
@ -526,9 +530,9 @@ try_again:
length - first_read); length - first_read);
/* Acknowledge the frame */ /* Acknowledge the frame */
reg = in_be32(ack); reg = __raw_readl(ack);
reg &= ~XEL_RSR_RECV_DONE_MASK; reg &= ~XEL_RSR_RECV_DONE_MASK;
out_be32(ack, reg); __raw_writel(reg, ack);
debug("Packet receive from 0x%p, length %dB\n", addr, length); debug("Packet receive from 0x%p, length %dB\n", addr, length);
*packetp = etherrxbuff; *packetp = etherrxbuff;