diff options
Diffstat (limited to 'drivers/net/sky2.c')
-rw-r--r-- | drivers/net/sky2.c | 52 |
1 files changed, 30 insertions, 22 deletions
diff --git a/drivers/net/sky2.c b/drivers/net/sky2.c index f68ccfbffff3..178249a96e1c 100644 --- a/drivers/net/sky2.c +++ b/drivers/net/sky2.c | |||
@@ -625,13 +625,16 @@ static void sky2_mac_init(struct sky2_hw *hw, unsigned port) | |||
625 | 625 | ||
626 | } | 626 | } |
627 | 627 | ||
628 | static void sky2_ramset(struct sky2_hw *hw, u16 q, u32 start, size_t len) | 628 | /* Assign Ram Buffer allocation. |
629 | * start and end are in units of 4k bytes | ||
630 | * ram registers are in units of 64bit words | ||
631 | */ | ||
632 | static void sky2_ramset(struct sky2_hw *hw, u16 q, u8 startk, u8 endk) | ||
629 | { | 633 | { |
630 | u32 end; | 634 | u32 start, end; |
631 | 635 | ||
632 | start /= 8; | 636 | start = startk * 4096/8; |
633 | len /= 8; | 637 | end = (endk * 4096/8) - 1; |
634 | end = start + len - 1; | ||
635 | 638 | ||
636 | sky2_write8(hw, RB_ADDR(q, RB_CTRL), RB_RST_CLR); | 639 | sky2_write8(hw, RB_ADDR(q, RB_CTRL), RB_RST_CLR); |
637 | sky2_write32(hw, RB_ADDR(q, RB_START), start); | 640 | sky2_write32(hw, RB_ADDR(q, RB_START), start); |
@@ -640,14 +643,19 @@ static void sky2_ramset(struct sky2_hw *hw, u16 q, u32 start, size_t len) | |||
640 | sky2_write32(hw, RB_ADDR(q, RB_RP), start); | 643 | sky2_write32(hw, RB_ADDR(q, RB_RP), start); |
641 | 644 | ||
642 | if (q == Q_R1 || q == Q_R2) { | 645 | if (q == Q_R1 || q == Q_R2) { |
643 | u32 rxup, rxlo; | 646 | u32 space = (endk - startk) * 4096/8; |
647 | u32 tp = space - space/4; | ||
644 | 648 | ||
645 | rxlo = len/2; | 649 | /* On receive queue's set the thresholds |
646 | rxup = rxlo + len/4; | 650 | * give receiver priority when > 3/4 full |
651 | * send pause when down to 2K | ||
652 | */ | ||
653 | sky2_write32(hw, RB_ADDR(q, RB_RX_UTHP), tp); | ||
654 | sky2_write32(hw, RB_ADDR(q, RB_RX_LTHP), space/2); | ||
647 | 655 | ||
648 | /* Set thresholds on receive queue's */ | 656 | tp = space - 2048/8; |
649 | sky2_write32(hw, RB_ADDR(q, RB_RX_UTPP), rxup); | 657 | sky2_write32(hw, RB_ADDR(q, RB_RX_UTPP), tp); |
650 | sky2_write32(hw, RB_ADDR(q, RB_RX_LTPP), rxlo); | 658 | sky2_write32(hw, RB_ADDR(q, RB_RX_LTPP), space/4); |
651 | } else { | 659 | } else { |
652 | /* Enable store & forward on Tx queue's because | 660 | /* Enable store & forward on Tx queue's because |
653 | * Tx FIFO is only 1K on Yukon | 661 | * Tx FIFO is only 1K on Yukon |
@@ -1002,19 +1010,19 @@ static int sky2_up(struct net_device *dev) | |||
1002 | 1010 | ||
1003 | sky2_mac_init(hw, port); | 1011 | sky2_mac_init(hw, port); |
1004 | 1012 | ||
1005 | /* Configure RAM buffers */ | 1013 | /* Determine available ram buffer space (in 4K blocks). |
1006 | if (hw->chip_id == CHIP_ID_YUKON_FE || | 1014 | * Note: not sure about the FE setting below yet |
1007 | (hw->chip_id == CHIP_ID_YUKON_EC && hw->chip_rev == 2)) | 1015 | */ |
1008 | ramsize = 4096; | 1016 | if (hw->chip_id == CHIP_ID_YUKON_FE) |
1009 | else { | 1017 | ramsize = 4; |
1010 | u8 e0 = sky2_read8(hw, B2_E_0); | 1018 | else |
1011 | ramsize = (e0 == 0) ? (128 * 1024) : (e0 * 4096); | 1019 | ramsize = sky2_read8(hw, B2_E_0); |
1012 | } | 1020 | |
1021 | /* Give transmitter one third (rounded up) */ | ||
1022 | rxspace = ramsize - (ramsize + 2) / 3; | ||
1013 | 1023 | ||
1014 | /* 2/3 for Rx */ | ||
1015 | rxspace = (2 * ramsize) / 3; | ||
1016 | sky2_ramset(hw, rxqaddr[port], 0, rxspace); | 1024 | sky2_ramset(hw, rxqaddr[port], 0, rxspace); |
1017 | sky2_ramset(hw, txqaddr[port], rxspace, ramsize - rxspace); | 1025 | sky2_ramset(hw, txqaddr[port], rxspace, ramsize); |
1018 | 1026 | ||
1019 | /* Make sure SyncQ is disabled */ | 1027 | /* Make sure SyncQ is disabled */ |
1020 | sky2_write8(hw, RB_ADDR(port == 0 ? Q_XS1 : Q_XS2, RB_CTRL), | 1028 | sky2_write8(hw, RB_ADDR(port == 0 ? Q_XS1 : Q_XS2, RB_CTRL), |