Commit 20094930 authored by Michael Chan's avatar Michael Chan Committed by David S. Miller

[TG3]: Add basic register access function pointers

This patch adds the basic function pointers to do register accesses in
the fast path. This was suggested by David Miller. The idea is that
various register access methods for different hardware errata can easily
be implemented with these function pointers and performance will not be
degraded on chips that use normal register access methods.

The various register read write macros (e.g. tw32, tr32, tw32_mailbox)
are redefined to call the function pointers.
Signed-off-by: default avatarMichael Chan <mchan@broadcom.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 757f612e
...@@ -366,7 +366,7 @@ static void _tw32_flush(struct tg3 *tp, u32 off, u32 val) ...@@ -366,7 +366,7 @@ static void _tw32_flush(struct tg3 *tp, u32 off, u32 val)
} }
} }
static inline void _tw32_rx_mbox(struct tg3 *tp, u32 off, u32 val) static void tg3_write32_rx_mbox(struct tg3 *tp, u32 off, u32 val)
{ {
void __iomem *mbox = tp->regs + off; void __iomem *mbox = tp->regs + off;
writel(val, mbox); writel(val, mbox);
...@@ -374,7 +374,7 @@ static inline void _tw32_rx_mbox(struct tg3 *tp, u32 off, u32 val) ...@@ -374,7 +374,7 @@ static inline void _tw32_rx_mbox(struct tg3 *tp, u32 off, u32 val)
readl(mbox); readl(mbox);
} }
static inline void _tw32_tx_mbox(struct tg3 *tp, u32 off, u32 val) static void tg3_write32_tx_mbox(struct tg3 *tp, u32 off, u32 val)
{ {
void __iomem *mbox = tp->regs + off; void __iomem *mbox = tp->regs + off;
writel(val, mbox); writel(val, mbox);
...@@ -384,17 +384,23 @@ static inline void _tw32_tx_mbox(struct tg3 *tp, u32 off, u32 val) ...@@ -384,17 +384,23 @@ static inline void _tw32_tx_mbox(struct tg3 *tp, u32 off, u32 val)
readl(mbox); readl(mbox);
} }
#define tw32_mailbox(reg, val) writel(((val) & 0xffffffff), tp->regs + (reg)) static void tg3_write32(struct tg3 *tp, u32 off, u32 val)
#define tw32_rx_mbox(reg, val) _tw32_rx_mbox(tp, reg, val) {
#define tw32_tx_mbox(reg, val) _tw32_tx_mbox(tp, reg, val) writel(val, tp->regs + off);
}
static u32 tg3_read32(struct tg3 *tp, u32 off)
{
return (readl(tp->regs + off));
}
#define tw32(reg,val) tg3_write_indirect_reg32(tp,(reg),(val)) #define tw32_mailbox(reg, val) tp->write32_mbox(tp, reg, val)
#define tw32_rx_mbox(reg, val) tp->write32_rx_mbox(tp, reg, val)
#define tw32_tx_mbox(reg, val) tp->write32_tx_mbox(tp, reg, val)
#define tw32(reg,val) tp->write32(tp, reg, val)
#define tw32_f(reg,val) _tw32_flush(tp,(reg),(val)) #define tw32_f(reg,val) _tw32_flush(tp,(reg),(val))
#define tw16(reg,val) writew(((val) & 0xffff), tp->regs + (reg)) #define tr32(reg) tp->read32(tp, reg)
#define tw8(reg,val) writeb(((val) & 0xff), tp->regs + (reg))
#define tr32(reg) readl(tp->regs + (reg))
#define tr16(reg) readw(tp->regs + (reg))
#define tr8(reg) readb(tp->regs + (reg))
static void tg3_write_mem(struct tg3 *tp, u32 off, u32 val) static void tg3_write_mem(struct tg3 *tp, u32 off, u32 val)
{ {
...@@ -9325,6 +9331,12 @@ static int __devinit tg3_get_invariants(struct tg3 *tp) ...@@ -9325,6 +9331,12 @@ static int __devinit tg3_get_invariants(struct tg3 *tp)
pci_write_config_dword(tp->pdev, TG3PCI_PCISTATE, pci_state_reg); pci_write_config_dword(tp->pdev, TG3PCI_PCISTATE, pci_state_reg);
} }
tp->read32 = tg3_read32;
tp->write32 = tg3_write_indirect_reg32;
tp->write32_mbox = tg3_write32;
tp->write32_tx_mbox = tg3_write32_tx_mbox;
tp->write32_rx_mbox = tg3_write32_rx_mbox;
/* Get eeprom hw config before calling tg3_set_power_state(). /* Get eeprom hw config before calling tg3_set_power_state().
* In particular, the TG3_FLAG_EEPROM_WRITE_PROT flag must be * In particular, the TG3_FLAG_EEPROM_WRITE_PROT flag must be
* determined before calling tg3_set_power_state() so that * determined before calling tg3_set_power_state() so that
......
...@@ -2049,6 +2049,10 @@ struct tg3 { ...@@ -2049,6 +2049,10 @@ struct tg3 {
spinlock_t lock; spinlock_t lock;
spinlock_t indirect_lock; spinlock_t indirect_lock;
u32 (*read32) (struct tg3 *, u32);
void (*write32) (struct tg3 *, u32, u32);
void (*write32_mbox) (struct tg3 *, u32,
u32);
void __iomem *regs; void __iomem *regs;
struct net_device *dev; struct net_device *dev;
struct pci_dev *pdev; struct pci_dev *pdev;
...@@ -2060,6 +2064,8 @@ struct tg3 { ...@@ -2060,6 +2064,8 @@ struct tg3 {
u32 msg_enable; u32 msg_enable;
/* begin "tx thread" cacheline section */ /* begin "tx thread" cacheline section */
void (*write32_tx_mbox) (struct tg3 *, u32,
u32);
u32 tx_prod; u32 tx_prod;
u32 tx_cons; u32 tx_cons;
u32 tx_pending; u32 tx_pending;
...@@ -2071,6 +2077,8 @@ struct tg3 { ...@@ -2071,6 +2077,8 @@ struct tg3 {
dma_addr_t tx_desc_mapping; dma_addr_t tx_desc_mapping;
/* begin "rx thread" cacheline section */ /* begin "rx thread" cacheline section */
void (*write32_rx_mbox) (struct tg3 *, u32,
u32);
u32 rx_rcb_ptr; u32 rx_rcb_ptr;
u32 rx_std_ptr; u32 rx_std_ptr;
u32 rx_jumbo_ptr; u32 rx_jumbo_ptr;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment