diff options
author | Matt Carlson <mcarlson@broadcom.com> | 2009-09-01 09:12:00 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2009-09-02 03:43:46 -0400 |
commit | b6080e126012047d42e53154189fdca286d0600e (patch) | |
tree | 254fb744e29dab5fc17baf4e37287a742dda9452 /drivers | |
parent | fed9781081aa9600765346c108ff22751e003715 (diff) |
tg3: Add coalesce parameters for msix vectors
This patch adds code to tune the coalescing parameters for the other
msix vectors.
Signed-off-by: Matt Carlson <mcarlson@broadcom.com>
Reviewed-by: Benjamin Li <benli@broadcom.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/net/tg3.c | 57 | ||||
-rw-r--r-- | drivers/net/tg3.h | 10 |
2 files changed, 57 insertions, 10 deletions
diff --git a/drivers/net/tg3.c b/drivers/net/tg3.c index a4e46e4de927..f51c29c64741 100644 --- a/drivers/net/tg3.c +++ b/drivers/net/tg3.c | |||
@@ -6876,24 +6876,63 @@ static void tg3_set_bdinfo(struct tg3 *tp, u32 bdinfo_addr, | |||
6876 | static void __tg3_set_rx_mode(struct net_device *); | 6876 | static void __tg3_set_rx_mode(struct net_device *); |
6877 | static void __tg3_set_coalesce(struct tg3 *tp, struct ethtool_coalesce *ec) | 6877 | static void __tg3_set_coalesce(struct tg3 *tp, struct ethtool_coalesce *ec) |
6878 | { | 6878 | { |
6879 | tw32(HOSTCC_RXCOL_TICKS, ec->rx_coalesce_usecs); | 6879 | int i; |
6880 | tw32(HOSTCC_TXCOL_TICKS, ec->tx_coalesce_usecs); | 6880 | |
6881 | tw32(HOSTCC_RXMAX_FRAMES, ec->rx_max_coalesced_frames); | 6881 | if (!(tp->tg3_flags2 & TG3_FLG2_USING_MSIX)) { |
6882 | tw32(HOSTCC_TXMAX_FRAMES, ec->tx_max_coalesced_frames); | 6882 | tw32(HOSTCC_TXCOL_TICKS, ec->tx_coalesce_usecs); |
6883 | if (!(tp->tg3_flags2 & TG3_FLG2_5705_PLUS)) { | 6883 | tw32(HOSTCC_TXMAX_FRAMES, ec->tx_max_coalesced_frames); |
6884 | tw32(HOSTCC_RXCOAL_TICK_INT, ec->rx_coalesce_usecs_irq); | 6884 | tw32(HOSTCC_TXCOAL_MAXF_INT, ec->tx_max_coalesced_frames_irq); |
6885 | tw32(HOSTCC_TXCOAL_TICK_INT, ec->tx_coalesce_usecs_irq); | 6885 | |
6886 | tw32(HOSTCC_RXCOL_TICKS, ec->rx_coalesce_usecs); | ||
6887 | tw32(HOSTCC_RXMAX_FRAMES, ec->rx_max_coalesced_frames); | ||
6888 | tw32(HOSTCC_RXCOAL_MAXF_INT, ec->rx_max_coalesced_frames_irq); | ||
6889 | } else { | ||
6890 | tw32(HOSTCC_TXCOL_TICKS, 0); | ||
6891 | tw32(HOSTCC_TXMAX_FRAMES, 0); | ||
6892 | tw32(HOSTCC_TXCOAL_MAXF_INT, 0); | ||
6893 | |||
6894 | tw32(HOSTCC_RXCOL_TICKS, 0); | ||
6895 | tw32(HOSTCC_RXMAX_FRAMES, 0); | ||
6896 | tw32(HOSTCC_RXCOAL_MAXF_INT, 0); | ||
6886 | } | 6897 | } |
6887 | tw32(HOSTCC_RXCOAL_MAXF_INT, ec->rx_max_coalesced_frames_irq); | 6898 | |
6888 | tw32(HOSTCC_TXCOAL_MAXF_INT, ec->tx_max_coalesced_frames_irq); | ||
6889 | if (!(tp->tg3_flags2 & TG3_FLG2_5705_PLUS)) { | 6899 | if (!(tp->tg3_flags2 & TG3_FLG2_5705_PLUS)) { |
6890 | u32 val = ec->stats_block_coalesce_usecs; | 6900 | u32 val = ec->stats_block_coalesce_usecs; |
6891 | 6901 | ||
6902 | tw32(HOSTCC_RXCOAL_TICK_INT, ec->rx_coalesce_usecs_irq); | ||
6903 | tw32(HOSTCC_TXCOAL_TICK_INT, ec->tx_coalesce_usecs_irq); | ||
6904 | |||
6892 | if (!netif_carrier_ok(tp->dev)) | 6905 | if (!netif_carrier_ok(tp->dev)) |
6893 | val = 0; | 6906 | val = 0; |
6894 | 6907 | ||
6895 | tw32(HOSTCC_STAT_COAL_TICKS, val); | 6908 | tw32(HOSTCC_STAT_COAL_TICKS, val); |
6896 | } | 6909 | } |
6910 | |||
6911 | for (i = 0; i < tp->irq_cnt - 1; i++) { | ||
6912 | u32 reg; | ||
6913 | |||
6914 | reg = HOSTCC_RXCOL_TICKS_VEC1 + i * 0x18; | ||
6915 | tw32(reg, ec->rx_coalesce_usecs); | ||
6916 | reg = HOSTCC_TXCOL_TICKS_VEC1 + i * 0x18; | ||
6917 | tw32(reg, ec->tx_coalesce_usecs); | ||
6918 | reg = HOSTCC_RXMAX_FRAMES_VEC1 + i * 0x18; | ||
6919 | tw32(reg, ec->rx_max_coalesced_frames); | ||
6920 | reg = HOSTCC_TXMAX_FRAMES_VEC1 + i * 0x18; | ||
6921 | tw32(reg, ec->tx_max_coalesced_frames); | ||
6922 | reg = HOSTCC_RXCOAL_MAXF_INT_VEC1 + i * 0x18; | ||
6923 | tw32(reg, ec->rx_max_coalesced_frames_irq); | ||
6924 | reg = HOSTCC_TXCOAL_MAXF_INT_VEC1 + i * 0x18; | ||
6925 | tw32(reg, ec->tx_max_coalesced_frames_irq); | ||
6926 | } | ||
6927 | |||
6928 | for (; i < tp->irq_max - 1; i++) { | ||
6929 | tw32(HOSTCC_RXCOL_TICKS_VEC1 + i * 0x18, 0); | ||
6930 | tw32(HOSTCC_TXCOL_TICKS_VEC1 + i * 0x18, 0); | ||
6931 | tw32(HOSTCC_RXMAX_FRAMES_VEC1 + i * 0x18, 0); | ||
6932 | tw32(HOSTCC_TXMAX_FRAMES_VEC1 + i * 0x18, 0); | ||
6933 | tw32(HOSTCC_RXCOAL_MAXF_INT_VEC1 + i * 0x18, 0); | ||
6934 | tw32(HOSTCC_TXCOAL_MAXF_INT_VEC1 + i * 0x18, 0); | ||
6935 | } | ||
6897 | } | 6936 | } |
6898 | 6937 | ||
6899 | /* tp->lock is held. */ | 6938 | /* tp->lock is held. */ |
diff --git a/drivers/net/tg3.h b/drivers/net/tg3.h index d1c7addd1d2d..978b6d9546fb 100644 --- a/drivers/net/tg3.h +++ b/drivers/net/tg3.h | |||
@@ -1119,7 +1119,15 @@ | |||
1119 | #define HOSTCC_SND_CON_IDX_14 0x00003cf8 | 1119 | #define HOSTCC_SND_CON_IDX_14 0x00003cf8 |
1120 | #define HOSTCC_SND_CON_IDX_15 0x00003cfc | 1120 | #define HOSTCC_SND_CON_IDX_15 0x00003cfc |
1121 | #define HOSTCC_STATBLCK_RING1 0x00003d00 | 1121 | #define HOSTCC_STATBLCK_RING1 0x00003d00 |
1122 | /* 0x3d04 --> 0x4000 unused */ | 1122 | /* 0x3d00 --> 0x3d80 unused */ |
1123 | |||
1124 | #define HOSTCC_RXCOL_TICKS_VEC1 0x00003d80 | ||
1125 | #define HOSTCC_TXCOL_TICKS_VEC1 0x00003d84 | ||
1126 | #define HOSTCC_RXMAX_FRAMES_VEC1 0x00003d88 | ||
1127 | #define HOSTCC_TXMAX_FRAMES_VEC1 0x00003d8c | ||
1128 | #define HOSTCC_RXCOAL_MAXF_INT_VEC1 0x00003d90 | ||
1129 | #define HOSTCC_TXCOAL_MAXF_INT_VEC1 0x00003d94 | ||
1130 | /* 0x3d98 --> 0x4000 unused */ | ||
1123 | 1131 | ||
1124 | /* Memory arbiter control registers */ | 1132 | /* Memory arbiter control registers */ |
1125 | #define MEMARB_MODE 0x00004000 | 1133 | #define MEMARB_MODE 0x00004000 |