aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorMatt Carlson <mcarlson@broadcom.com>2010-06-05 13:24:30 -0400
committerDavid S. Miller <davem@davemloft.net>2010-06-06 20:55:58 -0400
commitf92d9dc1504a964acfe07e8036fa30dcef22d343 (patch)
tree725728b7cf59480858ad58c1d29a96537fd8f8ce /drivers
parenteedc765ca4b19a41cf0b921a492ac08d640060d1 (diff)
tg3: Relocate APE mutex regs for 5717+
The 5717 and later devices relocate the APE mutex registers. This patch organizes the code so that the driver can use the mutex registers in the old and new locations. Signed-off-by: Matt Carlson <mcarlson@broadcom.com> Signed-off-by: Michael Chan <mchan@broadcom.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/net/tg3.c44
-rw-r--r--drivers/net/tg3.h6
2 files changed, 38 insertions, 12 deletions
diff --git a/drivers/net/tg3.c b/drivers/net/tg3.c
index 573054ae7b58..bd331174550b 100644
--- a/drivers/net/tg3.c
+++ b/drivers/net/tg3.c
@@ -585,18 +585,23 @@ static void tg3_read_mem(struct tg3 *tp, u32 off, u32 *val)
585static void tg3_ape_lock_init(struct tg3 *tp) 585static void tg3_ape_lock_init(struct tg3 *tp)
586{ 586{
587 int i; 587 int i;
588 u32 regbase;
589
590 if (GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5761)
591 regbase = TG3_APE_LOCK_GRANT;
592 else
593 regbase = TG3_APE_PER_LOCK_GRANT;
588 594
589 /* Make sure the driver hasn't any stale locks. */ 595 /* Make sure the driver hasn't any stale locks. */
590 for (i = 0; i < 8; i++) 596 for (i = 0; i < 8; i++)
591 tg3_ape_write32(tp, TG3_APE_LOCK_GRANT + 4 * i, 597 tg3_ape_write32(tp, regbase + 4 * i, APE_LOCK_GRANT_DRIVER);
592 APE_LOCK_GRANT_DRIVER);
593} 598}
594 599
595static int tg3_ape_lock(struct tg3 *tp, int locknum) 600static int tg3_ape_lock(struct tg3 *tp, int locknum)
596{ 601{
597 int i, off; 602 int i, off;
598 int ret = 0; 603 int ret = 0;
599 u32 status; 604 u32 status, req, gnt;
600 605
601 if (!(tp->tg3_flags3 & TG3_FLG3_ENABLE_APE)) 606 if (!(tp->tg3_flags3 & TG3_FLG3_ENABLE_APE))
602 return 0; 607 return 0;
@@ -609,13 +614,21 @@ static int tg3_ape_lock(struct tg3 *tp, int locknum)
609 return -EINVAL; 614 return -EINVAL;
610 } 615 }
611 616
617 if (GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5761) {
618 req = TG3_APE_LOCK_REQ;
619 gnt = TG3_APE_LOCK_GRANT;
620 } else {
621 req = TG3_APE_PER_LOCK_REQ;
622 gnt = TG3_APE_PER_LOCK_GRANT;
623 }
624
612 off = 4 * locknum; 625 off = 4 * locknum;
613 626
614 tg3_ape_write32(tp, TG3_APE_LOCK_REQ + off, APE_LOCK_REQ_DRIVER); 627 tg3_ape_write32(tp, req + off, APE_LOCK_REQ_DRIVER);
615 628
616 /* Wait for up to 1 millisecond to acquire lock. */ 629 /* Wait for up to 1 millisecond to acquire lock. */
617 for (i = 0; i < 100; i++) { 630 for (i = 0; i < 100; i++) {
618 status = tg3_ape_read32(tp, TG3_APE_LOCK_GRANT + off); 631 status = tg3_ape_read32(tp, gnt + off);
619 if (status == APE_LOCK_GRANT_DRIVER) 632 if (status == APE_LOCK_GRANT_DRIVER)
620 break; 633 break;
621 udelay(10); 634 udelay(10);
@@ -623,7 +636,7 @@ static int tg3_ape_lock(struct tg3 *tp, int locknum)
623 636
624 if (status != APE_LOCK_GRANT_DRIVER) { 637 if (status != APE_LOCK_GRANT_DRIVER) {
625 /* Revoke the lock request. */ 638 /* Revoke the lock request. */
626 tg3_ape_write32(tp, TG3_APE_LOCK_GRANT + off, 639 tg3_ape_write32(tp, gnt + off,
627 APE_LOCK_GRANT_DRIVER); 640 APE_LOCK_GRANT_DRIVER);
628 641
629 ret = -EBUSY; 642 ret = -EBUSY;
@@ -634,7 +647,7 @@ static int tg3_ape_lock(struct tg3 *tp, int locknum)
634 647
635static void tg3_ape_unlock(struct tg3 *tp, int locknum) 648static void tg3_ape_unlock(struct tg3 *tp, int locknum)
636{ 649{
637 int off; 650 u32 gnt;
638 651
639 if (!(tp->tg3_flags3 & TG3_FLG3_ENABLE_APE)) 652 if (!(tp->tg3_flags3 & TG3_FLG3_ENABLE_APE))
640 return; 653 return;
@@ -647,8 +660,12 @@ static void tg3_ape_unlock(struct tg3 *tp, int locknum)
647 return; 660 return;
648 } 661 }
649 662
650 off = 4 * locknum; 663 if (GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5761)
651 tg3_ape_write32(tp, TG3_APE_LOCK_GRANT + off, APE_LOCK_GRANT_DRIVER); 664 gnt = TG3_APE_LOCK_GRANT;
665 else
666 gnt = TG3_APE_PER_LOCK_GRANT;
667
668 tg3_ape_write32(tp, gnt + 4 * locknum, APE_LOCK_GRANT_DRIVER);
652} 669}
653 670
654static void tg3_disable_ints(struct tg3 *tp) 671static void tg3_disable_ints(struct tg3 *tp)
@@ -6782,7 +6799,8 @@ static void tg3_restore_pci_state(struct tg3 *tp)
6782 /* Allow reads and writes to the APE register and memory space. */ 6799 /* Allow reads and writes to the APE register and memory space. */
6783 if (tp->tg3_flags3 & TG3_FLG3_ENABLE_APE) 6800 if (tp->tg3_flags3 & TG3_FLG3_ENABLE_APE)
6784 val |= PCISTATE_ALLOW_APE_CTLSPC_WR | 6801 val |= PCISTATE_ALLOW_APE_CTLSPC_WR |
6785 PCISTATE_ALLOW_APE_SHMEM_WR; 6802 PCISTATE_ALLOW_APE_SHMEM_WR |
6803 PCISTATE_ALLOW_APE_PSPACE_WR;
6786 pci_write_config_dword(tp->pdev, TG3PCI_PCISTATE, val); 6804 pci_write_config_dword(tp->pdev, TG3PCI_PCISTATE, val);
6787 6805
6788 pci_write_config_word(tp->pdev, PCI_COMMAND, tp->pci_cmd); 6806 pci_write_config_word(tp->pdev, PCI_COMMAND, tp->pci_cmd);
@@ -7720,7 +7738,8 @@ static int tg3_reset_hw(struct tg3 *tp, int reset_phy)
7720 */ 7738 */
7721 val = tr32(TG3PCI_PCISTATE); 7739 val = tr32(TG3PCI_PCISTATE);
7722 val |= PCISTATE_ALLOW_APE_CTLSPC_WR | 7740 val |= PCISTATE_ALLOW_APE_CTLSPC_WR |
7723 PCISTATE_ALLOW_APE_SHMEM_WR; 7741 PCISTATE_ALLOW_APE_SHMEM_WR |
7742 PCISTATE_ALLOW_APE_PSPACE_WR;
7724 tw32(TG3PCI_PCISTATE, val); 7743 tw32(TG3PCI_PCISTATE, val);
7725 } 7744 }
7726 7745
@@ -13242,7 +13261,8 @@ static int __devinit tg3_get_invariants(struct tg3 *tp)
13242 * APE register and memory space. 13261 * APE register and memory space.
13243 */ 13262 */
13244 pci_state_reg |= PCISTATE_ALLOW_APE_CTLSPC_WR | 13263 pci_state_reg |= PCISTATE_ALLOW_APE_CTLSPC_WR |
13245 PCISTATE_ALLOW_APE_SHMEM_WR; 13264 PCISTATE_ALLOW_APE_SHMEM_WR |
13265 PCISTATE_ALLOW_APE_PSPACE_WR;
13246 pci_write_config_dword(tp->pdev, TG3PCI_PCISTATE, 13266 pci_write_config_dword(tp->pdev, TG3PCI_PCISTATE,
13247 pci_state_reg); 13267 pci_state_reg);
13248 } 13268 }
diff --git a/drivers/net/tg3.h b/drivers/net/tg3.h
index ce9c4918c318..84ea0dca7d29 100644
--- a/drivers/net/tg3.h
+++ b/drivers/net/tg3.h
@@ -231,6 +231,7 @@
231#define PCISTATE_RETRY_SAME_DMA 0x00002000 231#define PCISTATE_RETRY_SAME_DMA 0x00002000
232#define PCISTATE_ALLOW_APE_CTLSPC_WR 0x00010000 232#define PCISTATE_ALLOW_APE_CTLSPC_WR 0x00010000
233#define PCISTATE_ALLOW_APE_SHMEM_WR 0x00020000 233#define PCISTATE_ALLOW_APE_SHMEM_WR 0x00020000
234#define PCISTATE_ALLOW_APE_PSPACE_WR 0x00040000
234#define TG3PCI_CLOCK_CTRL 0x00000074 235#define TG3PCI_CLOCK_CTRL 0x00000074
235#define CLOCK_CTRL_CORECLK_DISABLE 0x00000200 236#define CLOCK_CTRL_CORECLK_DISABLE 0x00000200
236#define CLOCK_CTRL_RXCLK_DISABLE 0x00000400 237#define CLOCK_CTRL_RXCLK_DISABLE 0x00000400
@@ -2209,6 +2210,11 @@
2209#define APE_EVENT_STATUS_STATE_SUSPEND 0x00040000 2210#define APE_EVENT_STATUS_STATE_SUSPEND 0x00040000
2210#define APE_EVENT_STATUS_EVENT_PENDING 0x80000000 2211#define APE_EVENT_STATUS_EVENT_PENDING 0x80000000
2211 2212
2213#define TG3_APE_PER_LOCK_REQ 0x8400
2214#define APE_LOCK_PER_REQ_DRIVER 0x00001000
2215#define TG3_APE_PER_LOCK_GRANT 0x8420
2216#define APE_PER_LOCK_GRANT_DRIVER 0x00001000
2217
2212/* APE convenience enumerations. */ 2218/* APE convenience enumerations. */
2213#define TG3_APE_LOCK_GRC 1 2219#define TG3_APE_LOCK_GRC 1
2214#define TG3_APE_LOCK_MEM 4 2220#define TG3_APE_LOCK_MEM 4